@etherisc/gif-next 0.0.2-979c9aa-391 → 0.0.2-989147f-853
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +8 -13
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +1376 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1556 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +819 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +1000 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +840 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +73 -83
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +275 -1359
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +289 -214
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +441 -2539
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +472 -181
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +124 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +432 -280
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +427 -471
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +316 -145
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +2847 -0
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
- package/artifacts/contracts/instance/{Cloneable.sol → base/Cloneable.sol}/Cloneable.json +6 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +49 -0
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +93 -14
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +38 -13
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +256 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +59 -65
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.json +10 -0
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1288 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +735 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +329 -263
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +1095 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1077 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.json +1407 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1622 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +747 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +918 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +687 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1386 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +787 -0
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IComponentOwnerService.sol/IComponentOwnerService.json → product/IApplicationService.sol/IApplicationService.json} +231 -204
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +753 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IPolicyService.sol/IPolicyService.json +277 -290
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IPoolService.sol/IPoolService.json → product/IPricingService.sol/IPricingService.json} +254 -243
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +861 -0
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IProductService.sol/IProductService.json +85 -179
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1281 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +779 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +1004 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +727 -0
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
- package/artifacts/contracts/product/Product.sol/Product.json +1198 -0
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +864 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +679 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +15 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +283 -131
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +268 -255
- 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 +302 -231
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +238 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +313 -354
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +322 -138
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +846 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +132 -57
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +1206 -0
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/shared/Component.sol/Component.json +873 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +631 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/{components/BaseComponent.sol/BaseComponent.json → shared/IComponent.sol/IComponent.json} +249 -82
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +27 -29
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +189 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +8 -34
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/{experiment/inheritance/IA.sol/ISharedA.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +15 -17
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +84 -178
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -152
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +109 -29
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +302 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +310 -61
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +118 -53
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +71 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +185 -165
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +24 -6
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +2 -152
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/base/ComponentServiceBase.sol/ComponentServiceBase.json → staking/IStakingService.sol/IStakingService.json} +209 -207
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +767 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +667 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/AddressSet.sol/LibAddressSet.json +3 -3
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +281 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Blocknumber.sol/BlocknumberLib.json +3 -3
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +179 -0
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/DistributorType.sol/DistributorTypeLib.json +5 -5
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Key32.sol/Key32Lib.json +3 -3
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +166 -0
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/NftIdSet.sol/LibNftIdSet.json +3 -3
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/ObjectType.sol/ObjectTypeLib.json +3 -3
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/RiskId.sol/RiskIdLib.json +5 -5
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/RoleId.sol/RoleIdLib.json +5 -5
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +124 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/StateId.sol/StateIdLib.json +3 -3
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Timestamp.sol/TimestampLib.json +39 -8
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/UFixed.sol/MathLib.json +3 -3
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/UFixed.sol/UFixedLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Version.sol/VersionPartLib.json +3 -3
- package/contracts/distribution/Distribution.sol +285 -0
- package/contracts/distribution/DistributionService.sol +351 -0
- package/contracts/{instance/service → distribution}/DistributionServiceManager.sol +20 -20
- package/contracts/distribution/IDistributionComponent.sol +71 -0
- package/contracts/distribution/IDistributionService.sol +87 -0
- package/contracts/instance/BundleManager.sol +22 -25
- package/contracts/instance/IInstance.sol +56 -41
- package/contracts/instance/IInstanceService.sol +51 -16
- package/contracts/instance/Instance.sol +149 -196
- package/contracts/instance/InstanceAccessManager.sol +406 -167
- package/contracts/instance/InstanceAuthorizationsLib.sol +308 -0
- package/contracts/instance/InstanceReader.sol +102 -49
- package/contracts/instance/InstanceService.sol +214 -207
- package/contracts/instance/InstanceServiceManager.sol +15 -15
- package/contracts/instance/InstanceStore.sol +211 -0
- package/contracts/instance/{Cloneable.sol → base/Cloneable.sol} +8 -3
- package/contracts/instance/base/IKeyValueStore.sol +14 -10
- package/contracts/instance/base/ILifecycle.sol +3 -3
- package/contracts/instance/base/KeyValueStore.sol +44 -47
- package/contracts/instance/base/Lifecycle.sol +28 -7
- package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +16 -35
- package/contracts/instance/module/IAccess.sol +25 -19
- package/contracts/instance/module/IBundle.sol +11 -8
- package/contracts/instance/module/IComponents.sol +41 -0
- package/contracts/instance/module/IDistribution.sol +7 -4
- package/contracts/instance/module/IPolicy.sol +50 -17
- package/contracts/instance/module/IRisk.sol +1 -1
- package/contracts/instance/module/ISetup.sol +9 -22
- package/contracts/instance/module/ITreasury.sol +2 -2
- package/contracts/pool/BundleService.sol +384 -0
- package/contracts/{instance/service → pool}/BundleServiceManager.sol +19 -19
- package/contracts/pool/IBundleService.sol +118 -0
- package/contracts/pool/IPoolComponent.sol +114 -0
- package/contracts/pool/IPoolService.sol +114 -0
- package/contracts/pool/Pool.sol +302 -0
- package/contracts/pool/PoolService.sol +416 -0
- package/contracts/{instance/service → pool}/PoolServiceManager.sol +19 -19
- package/contracts/product/ApplicationService.sol +187 -0
- package/contracts/product/ApplicationServiceManager.sol +38 -0
- package/contracts/product/ClaimService.sol +443 -0
- package/contracts/product/ClaimServiceManager.sol +38 -0
- package/contracts/product/IApplicationService.sol +62 -0
- package/contracts/product/IClaimService.sol +93 -0
- package/contracts/product/IPolicyService.sol +80 -0
- package/contracts/product/IPricingService.sol +37 -0
- package/contracts/product/IProductComponent.sol +41 -0
- package/contracts/{instance/service → product}/IProductService.sol +10 -10
- package/contracts/product/PolicyService.sol +378 -0
- package/contracts/{instance/service → product}/PolicyServiceManager.sol +16 -13
- package/contracts/product/PricingService.sol +276 -0
- package/contracts/product/PricingServiceManager.sol +42 -0
- package/contracts/product/Product.sol +379 -0
- package/contracts/product/ProductService.sol +212 -0
- package/contracts/{instance/service → product}/ProductServiceManager.sol +16 -13
- package/contracts/registry/ChainNft.sol +9 -1
- package/contracts/registry/IRegistry.sol +52 -27
- package/contracts/registry/IRegistryService.sol +36 -28
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +253 -234
- package/contracts/registry/RegistryAccessManager.sol +132 -0
- package/contracts/registry/RegistryService.sol +81 -208
- package/contracts/registry/RegistryServiceManager.sol +34 -42
- package/contracts/registry/ReleaseManager.sol +380 -0
- package/contracts/registry/TokenRegistry.sol +22 -17
- package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +13 -0
- package/contracts/shared/Component.sol +271 -0
- package/contracts/shared/ComponentService.sol +141 -0
- package/contracts/shared/ERC165.sol +14 -12
- package/contracts/shared/IComponent.sol +90 -0
- package/contracts/shared/INftOwnable.sol +12 -11
- package/contracts/shared/IPolicyHolder.sol +40 -0
- package/contracts/shared/IRegisterable.sol +4 -6
- package/contracts/shared/IRegistryLinked.sol +11 -0
- package/contracts/shared/IService.sol +7 -4
- package/contracts/shared/IVersionable.sol +5 -48
- package/contracts/shared/NftOwnable.sol +64 -80
- package/contracts/shared/PolicyHolder.sol +94 -0
- package/contracts/shared/ProxyManager.sol +126 -25
- package/contracts/shared/Registerable.sol +26 -41
- package/contracts/shared/RegistryLinked.sol +43 -0
- package/contracts/shared/Service.sol +41 -24
- package/contracts/shared/TokenHandler.sol +14 -6
- package/contracts/shared/Versionable.sol +4 -92
- package/contracts/staking/IStakingService.sol +102 -0
- package/contracts/staking/StakingService.sol +169 -0
- package/contracts/staking/StakingServiceManager.sol +40 -0
- package/contracts/type/Amount.sol +109 -0
- package/contracts/{types → type}/Blocknumber.sol +1 -0
- package/contracts/type/ClaimId.sol +75 -0
- package/contracts/{types → type}/DistributorType.sol +2 -2
- package/contracts/{types → type}/Fee.sol +17 -8
- package/contracts/{types → type}/NftId.sol +8 -0
- package/contracts/{types → type}/NftIdSet.sol +1 -1
- package/contracts/{types → type}/ObjectType.sol +17 -7
- package/contracts/type/PayoutId.sol +82 -0
- package/contracts/{types → type}/Referral.sol +4 -0
- package/contracts/type/RoleId.sol +139 -0
- package/contracts/type/Seconds.sol +54 -0
- package/contracts/{types → type}/StateId.sol +7 -2
- package/contracts/{types → type}/Timestamp.sol +18 -13
- package/contracts/{types → type}/UFixed.sol +1 -0
- package/contracts/{types → type}/Version.sol +1 -0
- package/package.json +3 -3
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +0 -772
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -384
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -152
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +0 -275
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -157
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
- package/artifacts/contracts/components/Pool.sol/Pool.json +0 -967
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
- package/artifacts/contracts/components/Product.sol/Product.json +0 -883
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +0 -50
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
- package/artifacts/contracts/instance/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/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -285
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -923
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -440
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -827
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -684
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -428
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +0 -446
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -984
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -464
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -718
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -428
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -768
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -420
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +0 -4
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.json +0 -442
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -305
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
- package/artifacts/contracts/test/TestService.sol/TestService.json +0 -600
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -286
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
- package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -153
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -123
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
- package/contracts/components/BaseComponent.sol +0 -148
- package/contracts/components/Distribution.sol +0 -163
- package/contracts/components/IBaseComponent.sol +0 -32
- package/contracts/components/IDistributionComponent.sol +0 -44
- package/contracts/components/IPoolComponent.sol +0 -66
- package/contracts/components/IProductComponent.sol +0 -35
- package/contracts/components/Pool.sol +0 -271
- package/contracts/components/Product.sol +0 -292
- package/contracts/experiment/cloning/Cloner.sol +0 -47
- package/contracts/experiment/errors/Require.sol +0 -38
- package/contracts/experiment/errors/Revert.sol +0 -44
- package/contracts/experiment/inheritance/A.sol +0 -53
- package/contracts/experiment/inheritance/B.sol +0 -28
- package/contracts/experiment/inheritance/C.sol +0 -34
- package/contracts/experiment/inheritance/IA.sol +0 -13
- package/contracts/experiment/inheritance/IB.sol +0 -10
- package/contracts/experiment/inheritance/IC.sol +0 -12
- package/contracts/experiment/statemachine/Dummy.sol +0 -27
- package/contracts/experiment/statemachine/ISM.sol +0 -25
- package/contracts/experiment/statemachine/SM.sol +0 -57
- package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
- package/contracts/experiment/types/TypeA.sol +0 -47
- package/contracts/experiment/types/TypeB.sol +0 -29
- package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +0 -23
- package/contracts/instance/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/BundleService.sol +0 -260
- package/contracts/instance/service/ComponentOwnerService.sol +0 -317
- package/contracts/instance/service/DistributionService.sol +0 -118
- package/contracts/instance/service/IBundleService.sol +0 -45
- package/contracts/instance/service/IComponentOwnerService.sol +0 -20
- package/contracts/instance/service/IDistributionService.sol +0 -12
- package/contracts/instance/service/IPolicyService.sol +0 -87
- package/contracts/instance/service/IPoolService.sol +0 -20
- package/contracts/instance/service/PolicyService.sol +0 -508
- package/contracts/instance/service/PoolService.sol +0 -124
- package/contracts/instance/service/ProductService.sol +0 -173
- package/contracts/shared/ContractDeployerLib.sol +0 -72
- package/contracts/shared/RegisterableUpgradable.sol +0 -16
- package/contracts/test/TestFee.sol +0 -25
- package/contracts/test/TestRegisterable.sol +0 -18
- package/contracts/test/TestRoleId.sol +0 -14
- package/contracts/test/TestService.sol +0 -24
- package/contracts/test/TestToken.sol +0 -26
- package/contracts/test/TestVersion.sol +0 -44
- package/contracts/test/TestVersionable.sol +0 -17
- package/contracts/test/Usdc.sol +0 -26
- package/contracts/types/ChainId.sol +0 -38
- package/contracts/types/NumberId.sol +0 -52
- package/contracts/types/RoleId.sol +0 -91
- /package/contracts/{types → type}/AddressSet.sol +0 -0
- /package/contracts/{types → type}/Key32.sol +0 -0
- /package/contracts/{types → type}/RiskId.sol +0 -0
@@ -1,297 +1,536 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
+
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
4
5
|
import {EnumerableSet} from "@openzeppelin/contracts/utils/structs/EnumerableSet.sol";
|
5
6
|
import {ShortString, ShortStrings} from "@openzeppelin/contracts/utils/ShortStrings.sol";
|
6
|
-
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
7
7
|
|
8
|
-
import {
|
9
|
-
import {
|
10
|
-
import {
|
8
|
+
import {RoleId, RoleIdLib, ADMIN_ROLE, PUBLIC_ROLE, INSTANCE_SERVICE_ROLE, INSTANCE_OWNER_ROLE, INSTANCE_ROLE} from "../type/RoleId.sol";
|
9
|
+
import {TimestampLib} from "../type/Timestamp.sol";
|
10
|
+
import {NftId} from "../type/NftId.sol";
|
11
|
+
|
12
|
+
import {AccessManagerUpgradeableInitializeable} from "../shared/AccessManagerUpgradeableInitializeable.sol";
|
13
|
+
|
14
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
15
|
+
|
16
|
+
import {IInstance} from "./IInstance.sol";
|
11
17
|
import {IAccess} from "./module/IAccess.sol";
|
12
18
|
|
13
19
|
contract InstanceAccessManager is
|
14
20
|
AccessManagedUpgradeable
|
15
21
|
{
|
22
|
+
event LogRoleCreation(RoleId roleId, ShortString name, IAccess.Type rtype);
|
23
|
+
event LogTargetCreation(address target, ShortString name, IAccess.Type ttype, bool isLocked);
|
24
|
+
|
16
25
|
using RoleIdLib for RoleId;
|
17
26
|
|
18
27
|
string public constant ADMIN_ROLE_NAME = "AdminRole";
|
19
28
|
string public constant PUBLIC_ROLE_NAME = "PublicRole";
|
29
|
+
string public constant INSTANCE_ROLE_NAME = "InstanceRole";
|
30
|
+
string public constant INSTANCE_OWNER_ROLE_NAME = "InstanceOwnerRole";
|
20
31
|
|
21
|
-
uint64 public constant CUSTOM_ROLE_ID_MIN = 10000;
|
32
|
+
uint64 public constant CUSTOM_ROLE_ID_MIN = 10000; // MUST be even
|
22
33
|
uint32 public constant EXECUTION_DELAY = 0;
|
23
34
|
|
24
35
|
// role specific state
|
25
|
-
mapping(RoleId roleId => IAccess.RoleInfo info) internal
|
36
|
+
mapping(RoleId roleId => IAccess.RoleInfo info) internal _roleInfo;
|
26
37
|
mapping(RoleId roleId => EnumerableSet.AddressSet roleMembers) internal _roleMembers;
|
27
|
-
mapping(ShortString name => RoleId roleId) internal
|
28
|
-
RoleId [] internal
|
38
|
+
mapping(ShortString name => RoleId roleId) internal _roleIdForName;
|
39
|
+
RoleId [] internal _roleIds;
|
40
|
+
uint64 _idNext;
|
29
41
|
|
30
42
|
// target specific state
|
31
|
-
mapping(address target => IAccess.TargetInfo info) internal
|
32
|
-
mapping(ShortString name => address target) internal
|
43
|
+
mapping(address target => IAccess.TargetInfo info) internal _targetInfo;
|
44
|
+
mapping(ShortString name => address target) internal _targetAddressForName;
|
33
45
|
address [] internal _targets;
|
34
46
|
|
35
47
|
AccessManagerUpgradeableInitializeable internal _accessManager;
|
48
|
+
IRegistry internal _registry;
|
49
|
+
|
50
|
+
modifier restrictedToRoleAdmin(RoleId roleId) {
|
51
|
+
RoleId admin = getRoleAdmin(roleId);
|
52
|
+
(bool inRole, uint32 executionDelay) = _accessManager.hasRole(admin.toInt(), _msgSender());
|
53
|
+
assert(executionDelay == 0); // to be sure no delayed execution functionality is used
|
54
|
+
if (!inRole) {
|
55
|
+
revert IAccess.ErrorIAccessCallerIsNotRoleAdmin(_msgSender(), roleId);
|
56
|
+
}
|
57
|
+
_;
|
58
|
+
}
|
36
59
|
|
37
|
-
|
60
|
+
// instance owner is granted upon instance nft minting in callback function
|
61
|
+
function initialize(address instanceAddress) external initializer
|
38
62
|
{
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
_accessManager.__AccessManagerUpgradeableInitializeable_init(address(this));
|
43
|
-
_accessManager.grantRole(_accessManager.ADMIN_ROLE(), initialAdmin, 0);
|
63
|
+
IInstance instance = IInstance(instanceAddress);
|
64
|
+
IRegistry registry = instance.getRegistry();
|
65
|
+
address authority = instance.authority();
|
44
66
|
|
45
|
-
__AccessManaged_init(
|
67
|
+
__AccessManaged_init(authority);
|
46
68
|
|
47
|
-
|
48
|
-
|
69
|
+
_accessManager = AccessManagerUpgradeableInitializeable(authority);
|
70
|
+
_registry = registry;
|
71
|
+
_idNext = CUSTOM_ROLE_ID_MIN;
|
49
72
|
|
50
|
-
|
51
|
-
|
73
|
+
_createRole(ADMIN_ROLE(), ADMIN_ROLE_NAME, IAccess.Type.Core);
|
74
|
+
_createRole(PUBLIC_ROLE(), PUBLIC_ROLE_NAME, IAccess.Type.Core);
|
75
|
+
_createRole(INSTANCE_ROLE(), INSTANCE_ROLE_NAME, IAccess.Type.Core);
|
76
|
+
_createRole(INSTANCE_OWNER_ROLE(), INSTANCE_OWNER_ROLE_NAME, IAccess.Type.Gif);// TODO should be of core type
|
52
77
|
|
53
|
-
|
54
|
-
|
55
|
-
_createRole(POOL_OWNER_ROLE(), "PoolOwnerRole", false, true);
|
56
|
-
_createRole(PRODUCT_OWNER_ROLE(), "ProductOwnerRole", false, true);
|
78
|
+
// assume `this` is already a member of ADMIN_ROLE
|
79
|
+
EnumerableSet.add(_roleMembers[ADMIN_ROLE()], address(this));
|
57
80
|
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
_createRole(POLICY_SERVICE_ROLE(), "PolicyServiceRole", false, true);
|
62
|
-
_createRole(BUNDLE_SERVICE_ROLE(), "BundleServiceRole", false, true);
|
63
|
-
_createRole(INSTANCE_SERVICE_ROLE(), "InstanceServiceRole", false, true);
|
81
|
+
// grant instance role to instance contract address
|
82
|
+
grantRole(INSTANCE_ROLE(), instanceAddress);
|
83
|
+
setRoleAdmin(INSTANCE_OWNER_ROLE(), INSTANCE_ROLE());
|
64
84
|
}
|
65
85
|
|
66
86
|
//--- Role ------------------------------------------------------//
|
67
|
-
|
68
|
-
|
87
|
+
// ADMIN_ROLE
|
88
|
+
// assume all core roles are know at deployment time
|
89
|
+
// assume core roles are set and granted only during instance cloning
|
90
|
+
// assume core roles are never revoked -> core roles admin is never active after intialization
|
91
|
+
function createCoreRole(RoleId roleId, string memory name)
|
92
|
+
external
|
93
|
+
restricted()
|
94
|
+
{
|
95
|
+
_createRole(roleId, name, IAccess.Type.Core);
|
69
96
|
}
|
70
97
|
|
71
|
-
|
72
|
-
|
98
|
+
// ADMIN_ROLE
|
99
|
+
// assume gif roles can be revoked
|
100
|
+
// assume admin is INSTANCE_OWNER_ROLE or INSTANCE_ROLE
|
101
|
+
function createGifRole(RoleId roleId, string memory name, RoleId admin)
|
102
|
+
external
|
103
|
+
restricted()
|
104
|
+
{
|
105
|
+
_createRole(roleId, name, IAccess.Type.Gif);
|
106
|
+
setRoleAdmin(roleId, admin);
|
73
107
|
}
|
74
108
|
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
109
|
+
// INSTANCE_OWNER_ROLE
|
110
|
+
// TODO specify how many owners role can have -> many roles MUST have exactly 1 member?
|
111
|
+
function createRole(string memory roleName, string memory adminName)
|
112
|
+
external
|
113
|
+
restricted()
|
114
|
+
returns(RoleId roleId, RoleId admin)
|
115
|
+
{
|
116
|
+
(roleId, admin) = _getNextCustomRoleId();
|
79
117
|
|
80
|
-
|
81
|
-
|
82
|
-
}
|
118
|
+
_createRole(roleId, roleName, IAccess.Type.Custom);
|
119
|
+
_createRole(admin, adminName, IAccess.Type.Custom);
|
83
120
|
|
84
|
-
|
85
|
-
|
121
|
+
// TODO works without this -> why?
|
122
|
+
setRoleAdmin(roleId, admin);
|
123
|
+
setRoleAdmin(admin, INSTANCE_OWNER_ROLE());
|
86
124
|
}
|
87
125
|
|
88
|
-
|
126
|
+
// ADMIN_ROLE
|
127
|
+
// assume used by instance service only during instance cloning
|
128
|
+
// assume used only by this.createRole(), this.createGifRole() afterwards
|
129
|
+
function setRoleAdmin(RoleId roleId, RoleId admin)
|
130
|
+
public
|
131
|
+
restricted()
|
132
|
+
{
|
89
133
|
if (!roleExists(roleId)) {
|
90
|
-
revert IAccess.
|
134
|
+
revert IAccess.ErrorIAccessRoleIdDoesNotExist(roleId);
|
91
135
|
}
|
92
136
|
|
93
|
-
if
|
94
|
-
revert IAccess.
|
137
|
+
if(_roleInfo[roleId].rtype == IAccess.Type.Core) {
|
138
|
+
revert IAccess.ErrorIAccessRoleTypeInvalid(roleId, IAccess.Type.Core);
|
95
139
|
}
|
96
140
|
|
97
|
-
if (!
|
98
|
-
|
99
|
-
|
100
|
-
return true;
|
101
|
-
}
|
141
|
+
if (!roleExists(admin)) {
|
142
|
+
revert IAccess.ErrorIAccessRoleIdDoesNotExist(admin);
|
143
|
+
}
|
102
144
|
|
103
|
-
|
145
|
+
_roleInfo[roleId].admin = admin;
|
104
146
|
}
|
105
147
|
|
106
|
-
|
148
|
+
// TODO core role can be granted only to 1 member
|
149
|
+
function grantRole(RoleId roleId, address member)
|
150
|
+
public
|
151
|
+
restrictedToRoleAdmin(roleId)
|
152
|
+
returns (bool granted)
|
153
|
+
{
|
107
154
|
if (!roleExists(roleId)) {
|
108
|
-
revert IAccess.
|
155
|
+
revert IAccess.ErrorIAccessRoleIdDoesNotExist(roleId);
|
109
156
|
}
|
110
157
|
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
}
|
116
|
-
|
117
|
-
return false;
|
158
|
+
granted = EnumerableSet.add(_roleMembers[roleId], member);
|
159
|
+
if(granted) {
|
160
|
+
_accessManager.grantRole(roleId.toInt(), member, EXECUTION_DELAY);
|
161
|
+
}
|
118
162
|
}
|
119
163
|
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
164
|
+
function revokeRole(RoleId roleId, address member)
|
165
|
+
external
|
166
|
+
restrictedToRoleAdmin(roleId)
|
167
|
+
returns (bool)
|
168
|
+
{
|
169
|
+
return _revokeRole(roleId, member);
|
170
|
+
}
|
124
171
|
|
172
|
+
// INSTANCE_OWNER_ROLE
|
173
|
+
// IMPORTANT: unbounded function, revoke all or revert
|
174
|
+
// Instance owner role decides what to do in case of custom role admin bening revoked, e.g.:
|
175
|
+
// 1) revoke custom role from ALL members
|
176
|
+
// 2) revoke custom role admin from ALL members
|
177
|
+
// 3) 1) + 2)
|
178
|
+
// 4) revoke only 1 member of custom role admin
|
179
|
+
function revokeRoleAllMembers(RoleId roleId)
|
180
|
+
external
|
181
|
+
restrictedToRoleAdmin(roleId)
|
182
|
+
returns (bool revoked)
|
183
|
+
{
|
125
184
|
if (!roleExists(roleId)) {
|
126
|
-
revert IAccess.
|
185
|
+
revert IAccess.ErrorIAccessRoleIdDoesNotExist(roleId);
|
127
186
|
}
|
128
187
|
|
129
|
-
|
130
|
-
|
131
|
-
|
188
|
+
uint memberCount = EnumerableSet.length(_roleMembers[roleId]);
|
189
|
+
for(uint memberIdx = 0; memberIdx < memberCount; memberIdx++)
|
190
|
+
{
|
191
|
+
address member = EnumerableSet.at(_roleMembers[roleId], memberIdx);
|
132
192
|
EnumerableSet.remove(_roleMembers[roleId], member);
|
133
|
-
|
193
|
+
_accessManager.revokeRole(roleId.toInt(), member);
|
194
|
+
}
|
195
|
+
}
|
196
|
+
|
197
|
+
/// @dev not restricted function by intention
|
198
|
+
/// the restriction to role members is already enforced by the call to the access manager
|
199
|
+
function renounceRole(RoleId roleId)
|
200
|
+
external
|
201
|
+
returns (bool)
|
202
|
+
{
|
203
|
+
IAccess.Type rtype = _roleInfo[roleId].rtype;
|
204
|
+
if(rtype == IAccess.Type.Core || rtype == IAccess.Type.Gif) {
|
205
|
+
revert IAccess.ErrorIAccessRoleTypeInvalid(roleId, rtype);
|
134
206
|
}
|
135
207
|
|
136
|
-
|
208
|
+
address member = msg.sender;
|
209
|
+
// cannot use accessManger.renounce as it directly checks against msg.sender
|
210
|
+
return _revokeRole(roleId, member);
|
137
211
|
}
|
138
212
|
|
139
|
-
function
|
140
|
-
return
|
213
|
+
function roleExists(RoleId roleId) public view returns (bool exists) {
|
214
|
+
return _roleInfo[roleId].createdAt.gtz();
|
215
|
+
}
|
216
|
+
// TODO returns ADMIN_ROLE id for non existent roleId
|
217
|
+
function getRoleAdmin(RoleId roleId) public view returns(RoleId admin) {
|
218
|
+
return _roleInfo[roleId].admin;
|
219
|
+
}
|
220
|
+
|
221
|
+
function getRoleInfo(RoleId roleId) external view returns (IAccess.RoleInfo memory info) {
|
222
|
+
return _roleInfo[roleId];
|
223
|
+
}
|
224
|
+
|
225
|
+
function roleMembers(RoleId roleId) public view returns (uint256 numberOfMembers) {
|
226
|
+
return EnumerableSet.length(_roleMembers[roleId]);
|
141
227
|
}
|
142
228
|
|
143
229
|
function getRoleId(uint256 idx) external view returns (RoleId roleId) {
|
144
|
-
return
|
230
|
+
return _roleIds[idx];
|
145
231
|
}
|
146
232
|
|
233
|
+
// TODO returns ADMIN_ROLE id for non existent name
|
147
234
|
function getRoleIdForName(string memory name) external view returns (RoleId roleId) {
|
148
|
-
return
|
235
|
+
return _roleIdForName[ShortStrings.toShortString(name)];
|
149
236
|
}
|
150
237
|
|
151
|
-
function
|
152
|
-
return
|
238
|
+
function roleMember(RoleId roleId, uint256 idx) external view returns (address member) {
|
239
|
+
return EnumerableSet.at(_roleMembers[roleId], idx);
|
153
240
|
}
|
154
241
|
|
155
242
|
function hasRole(RoleId roleId, address account) external view returns (bool accountHasRole) {
|
156
243
|
(accountHasRole, ) = _accessManager.hasRole(roleId.toInt(), account);
|
157
244
|
}
|
158
245
|
|
159
|
-
function
|
160
|
-
return
|
246
|
+
function roles() external view returns (uint256 numberOfRoles) {
|
247
|
+
return _roleIds.length;
|
161
248
|
}
|
162
249
|
|
163
|
-
|
164
|
-
|
250
|
+
//--- Target ------------------------------------------------------//
|
251
|
+
// ADMIN_ROLE
|
252
|
+
// assume some core targets are registred (instance) while others are not (instance accesss manager, instance reader, bundle manager)
|
253
|
+
function createCoreTarget(address target, string memory name) external restricted() {
|
254
|
+
_createTarget(target, name, IAccess.Type.Core);
|
165
255
|
}
|
256
|
+
// INSTANCE_SERVICE_ROLE
|
257
|
+
// TODO check for instance mismatch?
|
258
|
+
function createGifTarget(address target, string memory name) external restricted()
|
259
|
+
{
|
260
|
+
if(!_registry.isRegistered(target)) {
|
261
|
+
revert IAccess.ErrorIAccessTargetNotRegistered(target);
|
262
|
+
}
|
166
263
|
|
167
|
-
|
168
|
-
|
169
|
-
|
264
|
+
_createTarget(target, name, IAccess.Type.Gif);
|
265
|
+
}
|
266
|
+
// INSTANCE_OWNER_ROLE
|
267
|
+
// assume custom target.authority() is constant -> target MUST not be used with different instance access manager
|
268
|
+
// assume custom target can not be registered as component -> each service which is doing component registration MUST register a gif target
|
269
|
+
// assume custom target can not be registered as instance or service -> why?
|
270
|
+
// TODO check target associated with instance owner or instance or instance components or components helpers
|
271
|
+
function createTarget(address target, string memory name) external restricted()
|
272
|
+
{
|
273
|
+
_createTarget(target, name, IAccess.Type.Custom);
|
170
274
|
}
|
171
275
|
|
172
|
-
|
173
|
-
|
276
|
+
// TODO instance owner locks component instead of revoking it access to the instance...
|
277
|
+
function setTargetLockedByService(address target, bool locked)
|
278
|
+
external
|
279
|
+
restricted // INSTANCE_SERVICE_ROLE
|
280
|
+
{
|
281
|
+
_setTargetLocked(target, locked);
|
174
282
|
}
|
175
283
|
|
176
|
-
function
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
284
|
+
function setTargetLockedByInstance(address target, bool locked)
|
285
|
+
external
|
286
|
+
restricted // INSTANCE_ROLE
|
287
|
+
{
|
288
|
+
_setTargetLocked(target, locked);
|
289
|
+
}
|
290
|
+
|
291
|
+
|
292
|
+
// allowed combinations of roles and targets:
|
293
|
+
//1) set core role for core target
|
294
|
+
//2) set gif role for gif target
|
295
|
+
//3) set custom role for gif target
|
296
|
+
//4) set custom role for custom target
|
297
|
+
|
298
|
+
// ADMIN_ROLE if used only during initialization, works with:
|
299
|
+
// any roles for any targets
|
300
|
+
// INSTANCE_SERVICE_ROLE if used not only during initilization, works with:
|
301
|
+
// core roles for core targets
|
302
|
+
// gif roles for gif targets
|
303
|
+
function setCoreTargetFunctionRole(
|
304
|
+
string memory targetName,
|
305
|
+
bytes4[] calldata selectors,
|
306
|
+
RoleId roleId
|
307
|
+
)
|
308
|
+
public
|
309
|
+
virtual
|
310
|
+
restricted()
|
311
|
+
{
|
312
|
+
ShortString nameShort = ShortStrings.toShortString(targetName);
|
313
|
+
address target = _targetAddressForName[nameShort];
|
314
|
+
|
315
|
+
// not custom target
|
316
|
+
if(_targetInfo[target].ttype == IAccess.Type.Custom) {
|
317
|
+
revert IAccess.ErrorIAccessTargetTypeInvalid(target, IAccess.Type.Custom);
|
181
318
|
}
|
182
319
|
|
183
|
-
|
184
|
-
|
185
|
-
|
320
|
+
// not custom role
|
321
|
+
if(_roleInfo[roleId].rtype == IAccess.Type.Custom) {
|
322
|
+
revert IAccess.ErrorIAccessRoleTypeInvalid(roleId, IAccess.Type.Custom);
|
323
|
+
}
|
186
324
|
|
187
|
-
|
188
|
-
return _target[target].createdAt.gtz();
|
325
|
+
_setTargetFunctionRole(target, nameShort, selectors, roleId);
|
189
326
|
}
|
190
327
|
|
191
|
-
|
328
|
+
// INSTANCE_OWNER_ROLE
|
329
|
+
// gif role for gif target
|
330
|
+
// gif role for custom target
|
331
|
+
// custom role for gif target
|
332
|
+
// custom role for custom target
|
333
|
+
// TODO instance owner can mess with gif target (component) -> e.g. set custom role for function intendent to work with gif role
|
334
|
+
function setTargetFunctionRole(
|
335
|
+
string memory targetName,
|
336
|
+
bytes4[] calldata selectors,
|
337
|
+
RoleId roleId
|
338
|
+
)
|
339
|
+
public
|
340
|
+
virtual
|
341
|
+
restricted()
|
342
|
+
{
|
343
|
+
ShortString nameShort = ShortStrings.toShortString(targetName);
|
344
|
+
address target = _targetAddressForName[nameShort];
|
345
|
+
|
346
|
+
// not core target
|
347
|
+
if(_targetInfo[target].ttype == IAccess.Type.Core) {
|
348
|
+
revert IAccess.ErrorIAccessTargetTypeInvalid(target, IAccess.Type.Core);
|
349
|
+
}
|
192
350
|
|
193
|
-
|
194
|
-
if
|
195
|
-
|
351
|
+
// not core role
|
352
|
+
if(_roleInfo[roleId].rtype == IAccess.Type.Core) {
|
353
|
+
revert IAccess.ErrorIAccessRoleTypeInvalid(roleId, IAccess.Type.Core);
|
196
354
|
}
|
197
355
|
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
356
|
+
_setTargetFunctionRole(target, nameShort, selectors, roleId);
|
357
|
+
}
|
358
|
+
|
359
|
+
function getTargetAddress(string memory targetName) public view returns(address targetAddress) {
|
360
|
+
ShortString nameShort = ShortStrings.toShortString(targetName);
|
361
|
+
return _targetAddressForName[nameShort];
|
362
|
+
}
|
204
363
|
|
205
|
-
|
206
|
-
|
207
|
-
_roles.push(roleId);
|
364
|
+
function isTargetLocked(address target) public view returns (bool locked) {
|
365
|
+
return _targetInfo[target].isLocked;
|
208
366
|
}
|
209
367
|
|
210
|
-
function
|
211
|
-
|
212
|
-
|
213
|
-
|
214
|
-
)
|
368
|
+
function targetExists(address target) public view returns (bool exists) {
|
369
|
+
return _targetInfo[target].createdAt.gtz();
|
370
|
+
}
|
371
|
+
|
372
|
+
function getTargetInfo(address target) public view returns (IAccess.TargetInfo memory) {
|
373
|
+
return _targetInfo[target];
|
374
|
+
}
|
375
|
+
|
376
|
+
//--- Role internal view/pure functions --------------------------------------//
|
377
|
+
function _createRole(RoleId roleId, string memory roleName, IAccess.Type rtype)
|
215
378
|
internal
|
216
|
-
view
|
217
|
-
returns (IAccess.RoleInfo memory existingRole)
|
218
379
|
{
|
219
|
-
|
220
|
-
|
221
|
-
|
222
|
-
|
380
|
+
ShortString name = ShortStrings.toShortString(roleName);
|
381
|
+
_validateRole(roleId, name, rtype);
|
382
|
+
|
383
|
+
if(roleExists(roleId)) {
|
384
|
+
revert IAccess.ErrorIAccessRoleIdExists(roleId);
|
223
385
|
}
|
224
386
|
|
225
|
-
|
226
|
-
|
387
|
+
if (_roleIdForName[name].gtz()) {
|
388
|
+
revert IAccess.ErrorIAccessRoleNameExists(roleId, _roleIdForName[name], name);
|
389
|
+
}
|
390
|
+
|
391
|
+
_roleInfo[roleId] = IAccess.RoleInfo(
|
392
|
+
name,
|
393
|
+
rtype,
|
394
|
+
ADMIN_ROLE(),
|
395
|
+
TimestampLib.blockTimestamp(),
|
396
|
+
TimestampLib.blockTimestamp()
|
397
|
+
);
|
398
|
+
_roleIdForName[name] = roleId;
|
399
|
+
_roleIds.push(roleId);
|
400
|
+
|
401
|
+
emit LogRoleCreation(roleId, name, rtype);
|
402
|
+
}
|
227
403
|
|
228
|
-
|
229
|
-
|
404
|
+
function _validateRole(RoleId roleId, ShortString name, IAccess.Type rtype)
|
405
|
+
internal
|
406
|
+
view
|
407
|
+
{
|
408
|
+
uint roleIdInt = roleId.toInt();
|
409
|
+
if(rtype == IAccess.Type.Custom && roleIdInt < CUSTOM_ROLE_ID_MIN) {
|
410
|
+
revert IAccess.ErrorIAccessRoleIdTooSmall(roleId);
|
230
411
|
}
|
231
412
|
|
232
|
-
if
|
233
|
-
|
234
|
-
|
235
|
-
|
413
|
+
if(
|
414
|
+
rtype != IAccess.Type.Custom &&
|
415
|
+
roleIdInt >= CUSTOM_ROLE_ID_MIN &&
|
416
|
+
roleIdInt != PUBLIC_ROLE().toInt())
|
417
|
+
{
|
418
|
+
revert IAccess.ErrorIAccessRoleIdTooBig(roleId);
|
236
419
|
}
|
237
420
|
|
238
421
|
// role name checks
|
239
|
-
|
240
|
-
if (ShortStrings.byteLength(nameShort) == 0) {
|
422
|
+
if (ShortStrings.byteLength(name) == 0) {
|
241
423
|
revert IAccess.ErrorIAccessRoleNameEmpty(roleId);
|
242
424
|
}
|
425
|
+
}
|
426
|
+
|
427
|
+
function _revokeRole(RoleId roleId, address member)
|
428
|
+
internal
|
429
|
+
returns(bool revoked)
|
430
|
+
{
|
431
|
+
if (!roleExists(roleId)) {
|
432
|
+
revert IAccess.ErrorIAccessRoleIdDoesNotExist(roleId);
|
433
|
+
}
|
243
434
|
|
244
|
-
|
245
|
-
|
435
|
+
revoked = EnumerableSet.remove(_roleMembers[roleId], member);
|
436
|
+
if(revoked) {
|
437
|
+
_accessManager.revokeRole(roleId.toInt(), member);
|
246
438
|
}
|
247
439
|
}
|
248
440
|
|
249
|
-
function
|
250
|
-
|
251
|
-
|
441
|
+
function _getNextCustomRoleId()
|
442
|
+
internal
|
443
|
+
returns(RoleId roleId, RoleId admin)
|
444
|
+
{
|
445
|
+
uint64 roleIdInt = _idNext;
|
446
|
+
uint64 adminInt = roleIdInt + 1;
|
447
|
+
|
448
|
+
_idNext = roleIdInt + 2;
|
449
|
+
|
450
|
+
roleId = RoleIdLib.toRoleId(roleIdInt);
|
451
|
+
admin = RoleIdLib.toRoleId(adminInt);
|
452
|
+
}
|
453
|
+
|
454
|
+
//--- Target internal view/pure functions --------------------------------------//
|
455
|
+
function _createTarget(address target, string memory targetName, IAccess.Type ttype)
|
456
|
+
internal
|
457
|
+
{
|
458
|
+
ShortString name = ShortStrings.toShortString(targetName);
|
459
|
+
_validateTarget(target, name, ttype);
|
460
|
+
|
461
|
+
if (_targetInfo[target].createdAt.gtz()) {
|
462
|
+
revert IAccess.ErrorIAccessTargetExists(target, _targetInfo[target].name);
|
252
463
|
}
|
253
464
|
|
254
|
-
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
|
465
|
+
if (_targetAddressForName[name] != address(0)) {
|
466
|
+
revert IAccess.ErrorIAccessTargetNameExists(
|
467
|
+
target,
|
468
|
+
_targetAddressForName[name],
|
469
|
+
name);
|
470
|
+
}
|
260
471
|
|
261
|
-
|
262
|
-
|
472
|
+
bool isLocked = _accessManager.isTargetClosed(target);// sync with state in access manager
|
473
|
+
_targetInfo[target] = IAccess.TargetInfo(
|
474
|
+
name,
|
475
|
+
ttype,
|
476
|
+
isLocked,
|
477
|
+
TimestampLib.blockTimestamp(),
|
478
|
+
TimestampLib.blockTimestamp()
|
479
|
+
);
|
480
|
+
_targetAddressForName[name] = target;
|
263
481
|
_targets.push(target);
|
482
|
+
|
483
|
+
emit LogTargetCreation(target, name, ttype, isLocked);
|
264
484
|
}
|
265
485
|
|
266
|
-
function
|
267
|
-
|
486
|
+
function _validateTarget(address target, ShortString name, IAccess.Type ttype)
|
487
|
+
internal
|
488
|
+
view
|
489
|
+
{
|
490
|
+
address targetAuthority = AccessManagedUpgradeable(target).authority();
|
491
|
+
if(targetAuthority != authority()) {
|
492
|
+
revert IAccess.ErrorIAccessTargetAuthorityInvalid(target, targetAuthority);
|
493
|
+
}
|
494
|
+
|
495
|
+
if (ShortStrings.byteLength(name) == 0) {
|
496
|
+
revert IAccess.ErrorIAccessTargetNameEmpty(target);
|
497
|
+
}
|
268
498
|
}
|
269
499
|
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
|
274
|
-
|
275
|
-
|
500
|
+
// IMPORTANT: instance access manager MUST be of Core type -> otherwise can be locked forever
|
501
|
+
function _setTargetLocked(address target, bool locked) internal
|
502
|
+
{
|
503
|
+
IAccess.Type targetType = _targetInfo[target].ttype;
|
504
|
+
if(target == address(0) || targetType == IAccess.Type.NotInitialized) {
|
505
|
+
revert IAccess.ErrorIAccessTargetDoesNotExist(target);
|
506
|
+
}
|
507
|
+
|
508
|
+
if(targetType == IAccess.Type.Core) {
|
509
|
+
revert IAccess.ErrorIAccessTargetTypeInvalid(target, targetType);
|
510
|
+
}
|
511
|
+
|
512
|
+
_targetInfo[target].isLocked = locked;
|
513
|
+
_accessManager.setTargetClosed(target, locked);
|
276
514
|
}
|
277
515
|
|
278
|
-
function
|
279
|
-
|
516
|
+
function _setTargetFunctionRole(
|
517
|
+
address target,
|
518
|
+
ShortString name,
|
280
519
|
bytes4[] calldata selectors,
|
281
520
|
RoleId roleId
|
282
|
-
)
|
283
|
-
|
284
|
-
|
285
|
-
|
286
|
-
|
521
|
+
)
|
522
|
+
internal
|
523
|
+
{
|
524
|
+
if (target == address(0)) {
|
525
|
+
revert IAccess.ErrorIAccessTargetDoesNotExist(target);
|
526
|
+
}
|
287
527
|
|
288
|
-
|
289
|
-
|
290
|
-
|
528
|
+
if (!roleExists(roleId)) {
|
529
|
+
revert IAccess.ErrorIAccessRoleIdDoesNotExist(roleId);
|
530
|
+
}
|
291
531
|
|
292
|
-
|
293
|
-
|
294
|
-
_accessManager.setTargetClosed(target, closed);
|
532
|
+
uint64 roleIdInt = RoleId.unwrap(roleId);
|
533
|
+
_accessManager.setTargetFunctionRole(target, selectors, roleIdInt);
|
295
534
|
}
|
296
535
|
|
297
536
|
function canCall(
|
@@ -301,4 +540,4 @@ contract InstanceAccessManager is
|
|
301
540
|
) public view virtual returns (bool immediate, uint32 delay) {
|
302
541
|
return _accessManager.canCall(caller, target, selector);
|
303
542
|
}
|
304
|
-
}
|
543
|
+
}
|