@etherisc/gif-next 0.0.2-984cc08-642 → 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 +68 -54
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +273 -1592
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +264 -218
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +443 -2515
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +479 -178
- 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 +442 -249
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +413 -390
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +330 -95
- 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 +58 -75
- 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 +291 -276
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/{components/Pool.sol/Pool.json → pool/IPoolComponent.sol/IPoolComponent.json} +438 -201
- 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/IDistributionService.sol/IDistributionService.json → product/IApplicationService.sol/IApplicationService.json} +219 -172
- 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 +182 -302
- 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} +241 -230
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/{components/Product.sol/Product.json → product/IProductComponent.sol/IProductComponent.json} +239 -169
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IProductService.sol/IProductService.json +72 -166
- 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 +170 -17
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +208 -229
- 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 +196 -43
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +50 -97
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +323 -258
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +331 -81
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +397 -81
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +142 -54
- 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/{instance/base → shared}/ComponentService.sol/ComponentService.json +199 -163
- 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/Distribution.sol/Distribution.json → shared/IComponent.sol/IComponent.json} +163 -218
- 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 +71 -165
- 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 +173 -153
- 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/{components/Component.sol/Component.json → staking/IStakingService.sol/IStakingService.json} +219 -194
- 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 +15 -12
- package/contracts/distribution/IDistributionComponent.sol +71 -0
- package/contracts/distribution/IDistributionService.sol +87 -0
- package/contracts/instance/BundleManager.sol +15 -14
- package/contracts/instance/IInstance.sol +55 -40
- package/contracts/instance/IInstanceService.sol +49 -16
- package/contracts/instance/Instance.sol +149 -179
- package/contracts/instance/InstanceAccessManager.sol +406 -166
- package/contracts/instance/InstanceAuthorizationsLib.sol +308 -0
- package/contracts/instance/InstanceReader.sol +101 -26
- package/contracts/instance/InstanceService.sol +192 -253
- package/contracts/instance/InstanceServiceManager.sol +11 -8
- package/contracts/instance/InstanceStore.sol +211 -0
- package/contracts/instance/{Cloneable.sol → base/Cloneable.sol} +8 -3
- package/contracts/instance/base/IKeyValueStore.sol +14 -10
- package/contracts/instance/base/ILifecycle.sol +3 -3
- package/contracts/instance/base/KeyValueStore.sol +44 -47
- package/contracts/instance/base/Lifecycle.sol +28 -7
- package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +12 -14
- package/contracts/instance/module/IAccess.sol +24 -18
- 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 +15 -12
- 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 +15 -12
- 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 +8 -0
- package/contracts/registry/IRegistry.sol +36 -21
- package/contracts/registry/IRegistryService.sol +33 -32
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +160 -89
- package/contracts/registry/RegistryAccessManager.sol +51 -129
- package/contracts/registry/RegistryService.sol +79 -165
- package/contracts/registry/RegistryServiceManager.sol +28 -18
- package/contracts/registry/ReleaseManager.sol +235 -197
- package/contracts/registry/TokenRegistry.sol +21 -15
- 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 -4
- package/contracts/shared/IRegistryLinked.sol +11 -0
- package/contracts/shared/IService.sol +6 -4
- package/contracts/shared/IVersionable.sol +5 -48
- package/contracts/shared/NftOwnable.sol +64 -82
- 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 +33 -21
- 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/Component.sol/Component.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IComponent.sol/IComponent.json +0 -413
- 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/Product.sol/Product.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/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 -619
- 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 -261
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.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 -100
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1094
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -436
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -764
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -424
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -1219
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -492
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -798
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -424
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -848
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -424
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -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/Component.sol +0 -177
- package/contracts/components/Distribution.sol +0 -154
- package/contracts/components/IComponent.sol +0 -37
- 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 -258
- package/contracts/components/Product.sol +0 -295
- 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 -27
- package/contracts/instance/InstanceBase.sol +0 -38
- package/contracts/instance/base/ComponentService.sol +0 -133
- package/contracts/instance/base/IInstanceBase.sol +0 -21
- package/contracts/instance/service/BundleService.sol +0 -293
- package/contracts/instance/service/DistributionService.sol +0 -115
- package/contracts/instance/service/IBundleService.sol +0 -44
- package/contracts/instance/service/IDistributionService.sol +0 -12
- package/contracts/instance/service/IPolicyService.sol +0 -94
- package/contracts/instance/service/IPoolService.sol +0 -20
- package/contracts/instance/service/PolicyService.sol +0 -538
- package/contracts/instance/service/PoolService.sol +0 -142
- package/contracts/instance/service/ProductService.sol +0 -241
- package/contracts/shared/ContractDeployerLib.sol +0 -72
- package/contracts/test/TestFee.sol +0 -25
- package/contracts/test/TestRegisterable.sol +0 -18
- package/contracts/test/TestRoleId.sol +0 -14
- package/contracts/test/TestService.sol +0 -25
- package/contracts/test/TestToken.sol +0 -26
- package/contracts/test/TestVersion.sol +0 -44
- package/contracts/test/TestVersionable.sol +0 -17
- package/contracts/test/Usdc.sol +0 -26
- package/contracts/types/ChainId.sol +0 -38
- package/contracts/types/NumberId.sol +0 -52
- package/contracts/types/RoleId.sol +0 -90
- /package/contracts/{types → type}/AddressSet.sol +0 -0
- /package/contracts/{types → type}/Key32.sol +0 -0
- /package/contracts/{types → type}/RiskId.sol +0 -0
@@ -1,220 +1,242 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
+
import {Clones} from "@openzeppelin/contracts/proxy/Clones.sol";
|
5
|
+
import {IAccessManager} from "@openzeppelin/contracts/access/manager/IAccessManager.sol";
|
4
6
|
import {AccessManaged} from "@openzeppelin/contracts/access/manager/AccessManaged.sol";
|
5
7
|
|
6
|
-
import {NftId} from "../
|
7
|
-
import {RoleId} from "../
|
8
|
-
import {ObjectType, ObjectTypeLib, zeroObjectType, REGISTRY, SERVICE} from "../
|
9
|
-
import {VersionPart, VersionPartLib} from "../
|
10
|
-
import {Timestamp, TimestampLib} from "../
|
8
|
+
import {NftId} from "../type/NftId.sol";
|
9
|
+
import {RoleId, ADMIN_ROLE, PUBLIC_ROLE} from "../type/RoleId.sol";
|
10
|
+
import {ObjectType, ObjectTypeLib, zeroObjectType, REGISTRY, SERVICE} from "../type/ObjectType.sol";
|
11
|
+
import {Version, VersionLib, VersionPart, VersionPartLib} from "../type/Version.sol";
|
12
|
+
import {Timestamp, TimestampLib} from "../type/Timestamp.sol";
|
11
13
|
|
12
14
|
import {IService} from "../shared/IService.sol";
|
15
|
+
import {AccessManagerUpgradeableInitializeable} from "../shared/AccessManagerUpgradeableInitializeable.sol";
|
13
16
|
|
14
17
|
import {IRegistry} from "./IRegistry.sol";
|
15
18
|
import {Registry} from "./Registry.sol";
|
16
19
|
import {IRegistryService} from "./IRegistryService.sol";
|
17
20
|
import {RegistryAccessManager} from "./RegistryAccessManager.sol";
|
18
21
|
|
22
|
+
// gif admin is not technical, should sent simple txs
|
23
|
+
// foundation creates
|
24
|
+
// other guy deployes
|
25
|
+
// other guy checks (can precompute addresses and compare with what deployed)
|
26
|
+
// foundation activates
|
27
|
+
// TODO add function to deactivate releases
|
28
|
+
// TODO in next pr add getVersion() to releaseAccessManager only, set in initialize()
|
29
|
+
// TODO in next pr make single base for registry access manager, release access manager and instance access manager
|
19
30
|
|
20
31
|
contract ReleaseManager is AccessManaged
|
21
32
|
{
|
22
33
|
using ObjectTypeLib for ObjectType;
|
23
34
|
|
24
|
-
event LogReleaseCreation(VersionPart version,
|
35
|
+
event LogReleaseCreation(VersionPart version, bytes32 salt, AccessManagerUpgradeableInitializeable accessManager);
|
25
36
|
event LogReleaseActivation(VersionPart version);
|
26
37
|
|
27
|
-
// createNextRelease
|
28
|
-
error NotRegistryService();
|
29
|
-
error UnexpectedServiceAuthority(address expected, address found);
|
30
38
|
|
39
|
+
// prepareRelease
|
40
|
+
error ErrorReleaseManagerReleaseEmpty();
|
41
|
+
error ErrorReleaseManagerReleaseAlreadyCreated(VersionPart version);
|
42
|
+
|
31
43
|
// registerService
|
32
|
-
error
|
44
|
+
error ErrorReleaseManagerNotService(IService service);
|
45
|
+
error ErrorReleaseManagerServiceAddressInvalid(IService given, address expected);
|
33
46
|
|
34
47
|
// activateNextRelease
|
35
|
-
|
36
|
-
|
48
|
+
error ErrorReleaseManagerReleaseNotCreated(VersionPart releaseVersion);
|
49
|
+
error ErrorReleaseManagerReleaseRegistrationNotFinished(VersionPart releaseVersion, uint awaitingRegistration);
|
50
|
+
error ErrorReleaseManagerReleaseAlreadyActivated(VersionPart releaseVersion);
|
37
51
|
|
38
|
-
//
|
39
|
-
error
|
40
|
-
error
|
41
|
-
error SelfRegistration();
|
42
|
-
error RegisterableOwnerIsRegistered();
|
52
|
+
// _verifyService
|
53
|
+
error ErrorReleaseManagerServiceReleaseAuthorityMismatch(IService service, address serviceAuthority, address releaseAuthority);
|
54
|
+
error ErrorReleaseManagerServiceReleaseVersionMismatch(IService service, VersionPart serviceVersion, VersionPart releaseVersion);
|
43
55
|
|
44
56
|
// _verifyServiceInfo
|
45
|
-
error
|
46
|
-
error
|
47
|
-
|
48
|
-
|
49
|
-
error
|
50
|
-
error
|
51
|
-
error ConfigSelectorZero(uint configArrayIndex);
|
52
|
-
error SelectorAlreadyExists(VersionPart releaseVersion, ObjectType serviceDomain);
|
53
|
-
|
57
|
+
error ErrorReleaseManagerServiceInfoAddressInvalid(IService service, address expected);
|
58
|
+
error ErrorReleaseManagerServiceInfoInterceptorInvalid(IService service, bool isInterceptor);
|
59
|
+
error ErrorReleaseManagerServiceInfoTypeInvalid(IService service, ObjectType expected, ObjectType found);
|
60
|
+
error ErrorReleaseManagerServiceInfoOwnerInvalid(IService service, address expected, address found);
|
61
|
+
error ErrorReleaseManagerServiceSelfRegistration(IService service);
|
62
|
+
error ErrorReleaseManagerServiceOwnerRegistered(IService service, address owner);
|
54
63
|
|
55
|
-
|
56
|
-
|
64
|
+
// _verifyServiceAuthorizations
|
65
|
+
error ErrorReleaseManagerServiceRoleInvalid(address service, RoleId role);
|
57
66
|
|
58
|
-
|
59
|
-
|
67
|
+
RegistryAccessManager public immutable _accessManager;
|
68
|
+
IRegistry public immutable _registry;
|
60
69
|
|
61
|
-
mapping(VersionPart version =>
|
70
|
+
mapping(VersionPart version => AccessManagerUpgradeableInitializeable accessManager) internal _releaseAccessManager;
|
71
|
+
mapping(VersionPart version => IRegistry.ReleaseInfo info) internal _releaseInfo;
|
72
|
+
mapping(address registryService => bool isActive) internal _active;// have access to registry
|
62
73
|
|
63
|
-
|
74
|
+
VersionPart immutable internal _initial;// first active version
|
75
|
+
VersionPart internal _latest;// latest active version
|
76
|
+
VersionPart internal _next;// version to create and activate
|
64
77
|
|
65
|
-
uint _awaitingRegistration; // "services left to register" counter
|
66
|
-
|
67
|
-
mapping(address registryService => bool isActive) _active;
|
78
|
+
uint internal _awaitingRegistration; // "services left to register" counter
|
68
79
|
|
69
80
|
constructor(
|
70
81
|
RegistryAccessManager accessManager,
|
71
82
|
VersionPart initialVersion)
|
72
83
|
AccessManaged(accessManager.authority())
|
73
84
|
{
|
74
|
-
require(initialVersion.toInt() > 0, "ReleaseManager: initial version is 0");
|
75
|
-
|
76
85
|
_accessManager = accessManager;
|
77
|
-
|
78
86
|
_initial = initialVersion;
|
79
|
-
|
87
|
+
_next = VersionPartLib.toVersionPart(initialVersion.toInt() - 1);
|
80
88
|
_registry = new Registry();
|
81
89
|
}
|
82
90
|
|
83
|
-
|
84
|
-
|
85
|
-
function createNextRelease(IRegistryService service)
|
91
|
+
/// @dev skips previous release if it was not activated
|
92
|
+
function createNextRelease()
|
86
93
|
external
|
87
94
|
restricted // GIF_ADMIN_ROLE
|
88
|
-
returns(
|
95
|
+
returns(VersionPart version)
|
89
96
|
{
|
90
|
-
|
91
|
-
|
97
|
+
_next = VersionPartLib.toVersionPart(_next.toInt() + 1);
|
98
|
+
_awaitingRegistration = 0;
|
99
|
+
}
|
100
|
+
|
101
|
+
function prepareNextRelease(
|
102
|
+
address[] memory addresses,
|
103
|
+
RoleId[][] memory serviceRoles,
|
104
|
+
RoleId[][] memory functionRoles,
|
105
|
+
bytes4[][][] memory selectors,
|
106
|
+
bytes32 salt
|
107
|
+
)
|
108
|
+
external
|
109
|
+
restricted // GIF_MANAGER_ROLE
|
110
|
+
returns(address releaseAccessManagerAddress, VersionPart version, bytes32 releaseSalt)
|
111
|
+
{
|
112
|
+
if(addresses.length == 0) {
|
113
|
+
revert ErrorReleaseManagerReleaseEmpty();
|
92
114
|
}
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
revert UnexpectedServiceAuthority(
|
97
|
-
authority(),
|
98
|
-
serviceAuthority);
|
115
|
+
|
116
|
+
if(_awaitingRegistration > 0) {
|
117
|
+
revert ErrorReleaseManagerReleaseAlreadyCreated(version);
|
99
118
|
}
|
100
119
|
|
101
|
-
(
|
102
|
-
IRegistry.ObjectInfo memory info,
|
103
|
-
bytes memory data
|
104
|
-
) = _getAndVerifyContractInfo(service, SERVICE(), msg.sender);
|
120
|
+
_verifyReleaseAuthorizations(addresses, serviceRoles, functionRoles, selectors);
|
105
121
|
|
106
|
-
|
107
|
-
ObjectType domain = REGISTRY();
|
108
|
-
_verifyServiceInfo(info, version, domain);
|
122
|
+
version = getNextVersion();
|
109
123
|
|
110
|
-
|
124
|
+
_releaseInfo[version].version = version;
|
125
|
+
_releaseInfo[version].addresses = addresses;
|
126
|
+
_releaseInfo[version].serviceRoles = serviceRoles;
|
127
|
+
_releaseInfo[version].functionRoles = functionRoles;
|
128
|
+
_releaseInfo[version].selectors = selectors;
|
129
|
+
_awaitingRegistration = addresses.length;
|
111
130
|
|
112
|
-
|
113
|
-
|
114
|
-
|
131
|
+
version = getNextVersion();
|
132
|
+
// ensures unique salt
|
133
|
+
releaseSalt = keccak256(
|
134
|
+
bytes.concat(
|
135
|
+
bytes32(version.toInt()),
|
136
|
+
salt));
|
115
137
|
|
116
|
-
|
117
|
-
|
138
|
+
releaseAccessManagerAddress = Clones.cloneDeterministic(_accessManager.authority(), releaseSalt);
|
139
|
+
AccessManagerUpgradeableInitializeable releaseAccessManager = AccessManagerUpgradeableInitializeable(releaseAccessManagerAddress);
|
140
|
+
|
141
|
+
_releaseAccessManager[version] = releaseAccessManager;
|
142
|
+
|
143
|
+
releaseAccessManager.initialize(address(this));
|
118
144
|
|
119
|
-
emit LogReleaseCreation(version,
|
145
|
+
emit LogReleaseCreation(version, releaseSalt, releaseAccessManager);
|
120
146
|
}
|
121
147
|
|
122
|
-
// TODO adding service to release -> synchronized with proxy upgrades or simple addServiceToRelease(service, version, selector)?
|
123
|
-
// TODO removing service from release? -> set _active to false forever, but keep all other records?
|
124
148
|
function registerService(IService service)
|
125
149
|
external
|
126
150
|
restricted // GIF_MANAGER_ROLE
|
127
151
|
returns(NftId nftId)
|
128
152
|
{
|
129
|
-
if(!service.supportsInterface(type(IService).interfaceId)) {
|
130
|
-
revert NotService();
|
131
|
-
}
|
132
|
-
|
133
153
|
(
|
134
|
-
IRegistry.ObjectInfo memory info,
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
VersionPart version = getNextVersion();
|
139
|
-
ObjectType domain = _release[version].domains[_awaitingRegistration];// reversed registration order of services specified in RegistryService config
|
140
|
-
_verifyServiceInfo(info, version, domain);
|
141
|
-
|
142
|
-
// setup and grant unique role if service does registrations
|
143
|
-
address registryService = _registry.getServiceAddress(REGISTRY(), version);
|
144
|
-
bytes4[] memory selector = new bytes4[](1);
|
145
|
-
selector[0] = _selector[version][domain];
|
146
|
-
if(selector[0] != 0) {
|
147
|
-
_accessManager.setAndGrantUniqueRole(
|
148
|
-
address(service),
|
149
|
-
registryService,
|
150
|
-
selector);
|
151
|
-
}
|
154
|
+
IRegistry.ObjectInfo memory info,
|
155
|
+
ObjectType domain,
|
156
|
+
VersionPart version
|
157
|
+
) = _verifyService(service);
|
152
158
|
|
153
|
-
_awaitingRegistration
|
159
|
+
uint serviceIdx = _awaitingRegistration - 1;
|
160
|
+
address serviceAddress = _releaseInfo[version].addresses[serviceIdx];
|
161
|
+
if(address(service) != serviceAddress) {
|
162
|
+
revert ErrorReleaseManagerServiceAddressInvalid(service, serviceAddress);
|
163
|
+
}
|
154
164
|
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
165
|
+
_setServiceAuthorizations(
|
166
|
+
_releaseAccessManager[version],
|
167
|
+
serviceAddress,
|
168
|
+
_releaseInfo[version].serviceRoles[serviceIdx],
|
169
|
+
_releaseInfo[version].functionRoles[serviceIdx],
|
170
|
+
_releaseInfo[version].selectors[serviceIdx]);
|
159
171
|
|
160
|
-
|
161
|
-
|
172
|
+
_awaitingRegistration = serviceIdx;
|
173
|
+
// checked in registry
|
174
|
+
_releaseInfo[version].domains.push(domain);
|
162
175
|
|
163
176
|
nftId = _registry.registerService(info, version, domain);
|
164
177
|
|
165
|
-
|
166
|
-
service.linkToRegisteredNftId();
|
178
|
+
service.linkToRegisteredNftId();
|
167
179
|
}
|
168
180
|
|
169
|
-
|
181
|
+
function activateNextRelease()
|
170
182
|
external
|
171
183
|
restricted // GIF_ADMIN_ROLE
|
172
184
|
{
|
173
|
-
VersionPart version =
|
185
|
+
VersionPart version = _next;
|
174
186
|
address service = _registry.getServiceAddress(REGISTRY(), version);
|
175
187
|
|
176
|
-
// release
|
188
|
+
// release exists, registry service is a MUST
|
189
|
+
//if(_releaseAccessManager[version] == address(0)) {
|
177
190
|
if(service == address(0)) {
|
178
|
-
revert
|
191
|
+
revert ErrorReleaseManagerReleaseNotCreated(version);
|
179
192
|
}
|
180
193
|
|
181
194
|
// release fully deployed
|
182
195
|
if(_awaitingRegistration > 0) {
|
183
|
-
revert
|
196
|
+
revert ErrorReleaseManagerReleaseRegistrationNotFinished(version, _awaitingRegistration);
|
184
197
|
}
|
185
198
|
|
186
|
-
//
|
199
|
+
// release is not activated
|
200
|
+
if(_releaseInfo[version].activatedAt.gtz()) {
|
201
|
+
revert ErrorReleaseManagerReleaseAlreadyActivated(version);
|
202
|
+
}
|
187
203
|
|
188
204
|
_latest = version;
|
205
|
+
|
189
206
|
_active[service] = true;
|
207
|
+
_releaseInfo[version].activatedAt = TimestampLib.blockTimestamp();
|
190
208
|
|
191
|
-
LogReleaseActivation(version);
|
192
|
-
}
|
209
|
+
emit LogReleaseActivation(version);
|
210
|
+
}
|
193
211
|
|
194
212
|
//--- view functions ----------------------------------------------------//
|
195
213
|
|
196
|
-
function
|
197
|
-
|
214
|
+
function predictDeterministicAddress(
|
215
|
+
address implementation,
|
216
|
+
bytes32 salt,
|
217
|
+
address deployer
|
218
|
+
) external pure returns (address predicted) {
|
219
|
+
return Clones.predictDeterministicAddress(implementation, salt, deployer);
|
220
|
+
}
|
221
|
+
|
222
|
+
function isActiveRegistryService(address service) external view returns(bool) {
|
198
223
|
return _active[service];
|
199
224
|
}
|
200
225
|
|
201
|
-
function
|
202
|
-
|
203
|
-
return (address(_registry));
|
226
|
+
function isValidRelease(VersionPart version) external view returns(bool) {
|
227
|
+
return _releaseInfo[version].activatedAt.gtz();
|
204
228
|
}
|
205
229
|
|
206
|
-
function
|
207
|
-
|
208
|
-
return _release[version];
|
230
|
+
function getRegistry() external view returns(address) {
|
231
|
+
return (address(_registry));
|
209
232
|
}
|
210
233
|
|
211
|
-
function
|
212
|
-
|
213
|
-
|
234
|
+
function getReleaseInfo(VersionPart version) external view returns(IRegistry.ReleaseInfo memory) {
|
235
|
+
return _releaseInfo[version];
|
236
|
+
}
|
214
237
|
|
215
|
-
|
216
|
-
|
217
|
-
VersionPartLib.toVersionPart(latest + 1);
|
238
|
+
function getNextVersion() public view returns(VersionPart) {
|
239
|
+
return _next;
|
218
240
|
}
|
219
241
|
|
220
242
|
function getLatestVersion() external view returns(VersionPart) {
|
@@ -225,118 +247,134 @@ contract ReleaseManager is AccessManaged
|
|
225
247
|
return _initial;
|
226
248
|
}
|
227
249
|
|
250
|
+
function getReleaseAccessManager(VersionPart version) external view returns(AccessManagerUpgradeableInitializeable) {
|
251
|
+
return _releaseAccessManager[version];
|
252
|
+
}
|
253
|
+
|
228
254
|
//--- private functions ----------------------------------------------------//
|
229
255
|
|
230
|
-
function
|
256
|
+
function _verifyService(IService service)
|
257
|
+
internal
|
258
|
+
returns(
|
259
|
+
IRegistry.ObjectInfo memory serviceInfo,
|
260
|
+
ObjectType serviceDomain,
|
261
|
+
VersionPart serviceVersion
|
262
|
+
)
|
263
|
+
{
|
264
|
+
if(!service.supportsInterface(type(IService).interfaceId)) {
|
265
|
+
revert ErrorReleaseManagerNotService(service);
|
266
|
+
}
|
267
|
+
|
268
|
+
address owner = msg.sender;
|
269
|
+
address serviceAuthority = service.authority();
|
270
|
+
serviceVersion = service.getVersion().toMajorPart();
|
271
|
+
serviceDomain = service.getDomain();// checked in registry
|
272
|
+
serviceInfo = service.getInitialInfo();
|
273
|
+
|
274
|
+
_verifyServiceInfo(service, serviceInfo, owner);
|
275
|
+
|
276
|
+
VersionPart releaseVersion = getNextVersion(); // never 0
|
277
|
+
address releaseAuthority = address(_releaseAccessManager[releaseVersion]); // can be zero if registering service when release is not created
|
278
|
+
|
279
|
+
// IMPORTANT: can not guarantee service access is actually controlled by authority
|
280
|
+
if(serviceAuthority != releaseAuthority) {
|
281
|
+
revert ErrorReleaseManagerServiceReleaseAuthorityMismatch(
|
282
|
+
service,
|
283
|
+
serviceAuthority,
|
284
|
+
releaseAuthority);
|
285
|
+
}
|
286
|
+
|
287
|
+
if(serviceVersion != releaseVersion) {
|
288
|
+
revert ErrorReleaseManagerServiceReleaseVersionMismatch(
|
289
|
+
service,
|
290
|
+
serviceVersion,
|
291
|
+
releaseVersion);
|
292
|
+
}
|
293
|
+
}
|
294
|
+
|
295
|
+
function _verifyServiceInfo(
|
231
296
|
IService service,
|
232
|
-
|
297
|
+
IRegistry.ObjectInfo memory info,
|
233
298
|
address expectedOwner // assume always valid, can not be 0
|
234
299
|
)
|
235
300
|
internal
|
236
301
|
view
|
237
|
-
returns(
|
238
|
-
IRegistry.ObjectInfo memory info,
|
239
|
-
bytes memory data
|
240
|
-
)
|
241
302
|
{
|
242
|
-
(info
|
243
|
-
|
244
|
-
|
303
|
+
if(info.objectAddress != address(service)) {
|
304
|
+
revert ErrorReleaseManagerServiceInfoAddressInvalid(service, address(service));
|
305
|
+
}
|
245
306
|
|
246
|
-
if(info.
|
247
|
-
revert
|
307
|
+
if(info.isInterceptor != false) { // service is never interceptor
|
308
|
+
revert ErrorReleaseManagerServiceInfoInterceptorInvalid(service, info.isInterceptor);
|
309
|
+
}
|
310
|
+
|
311
|
+
if(info.objectType != SERVICE()) {// type is checked in registry anyway...but service logic may depend on expected value
|
312
|
+
revert ErrorReleaseManagerServiceInfoTypeInvalid(service, SERVICE(), info.objectType);
|
248
313
|
}
|
249
314
|
|
250
315
|
address owner = info.initialOwner;
|
251
316
|
|
252
317
|
if(owner != expectedOwner) { // registerable owner protection
|
253
|
-
revert
|
318
|
+
revert ErrorReleaseManagerServiceInfoOwnerInvalid(service, expectedOwner, owner);
|
254
319
|
}
|
255
320
|
|
256
321
|
if(owner == address(service)) {
|
257
|
-
revert
|
322
|
+
revert ErrorReleaseManagerServiceSelfRegistration(service);
|
258
323
|
}
|
259
|
-
|
260
|
-
/*if(owner == address(0)) { // never 0
|
261
|
-
revert();// RegisterableOwnerIsZero();
|
262
|
-
}*/
|
263
324
|
|
264
325
|
if(_registry.isRegistered(owner)) {
|
265
|
-
revert
|
326
|
+
revert ErrorReleaseManagerServiceOwnerRegistered(service, owner);
|
266
327
|
}
|
267
|
-
|
268
|
-
/*NftId parentNftId = info.parentNftId;
|
269
|
-
IRegistry.ObjectInfo memory parentInfo = getRegistry().getObjectInfo(parentNftId);
|
270
|
-
|
271
|
-
if(parentInfo.objectType != parentType) { // parent registration + type
|
272
|
-
revert InvalidParent(parentNftId);
|
273
|
-
}*/
|
274
|
-
|
275
|
-
return(info, data);
|
276
328
|
}
|
277
329
|
|
278
|
-
function
|
279
|
-
|
280
|
-
|
281
|
-
|
330
|
+
function _verifyReleaseAuthorizations(
|
331
|
+
address[] memory serviceAddress,
|
332
|
+
RoleId[][] memory serviceRoles,
|
333
|
+
RoleId[][] memory functionRoles,
|
334
|
+
bytes4[][][] memory selectors
|
282
335
|
)
|
283
336
|
internal
|
284
337
|
view
|
285
|
-
returns(ObjectType)
|
286
338
|
{
|
287
|
-
(
|
288
|
-
|
289
|
-
|
290
|
-
|
291
|
-
|
292
|
-
|
293
|
-
|
294
|
-
|
295
|
-
|
296
|
-
if(expectedDomain.gtz()) {
|
297
|
-
if(domain != expectedDomain) {
|
298
|
-
revert UnexpectedServiceDomain(expectedDomain, domain);
|
339
|
+
for(uint serviceIdx = 0; serviceIdx < serviceAddress.length; serviceIdx++)
|
340
|
+
{
|
341
|
+
for(uint roleIdx = 0; roleIdx < serviceRoles[serviceIdx].length; roleIdx++)
|
342
|
+
{
|
343
|
+
RoleId role = serviceRoles[serviceIdx][roleIdx];
|
344
|
+
if(role == ADMIN_ROLE()) {
|
345
|
+
revert ErrorReleaseManagerServiceRoleInvalid(serviceAddress[serviceIdx], role);
|
346
|
+
}
|
299
347
|
}
|
300
348
|
}
|
301
|
-
|
302
|
-
|
349
|
+
// TODO no duplicate service "domain" role per release
|
350
|
+
// TODO no duplicate service roles per service
|
351
|
+
// TODO no duplicate service function roles per service
|
352
|
+
// TODO no duplicate service function selectors per service
|
303
353
|
}
|
304
354
|
|
305
|
-
|
306
|
-
|
355
|
+
function _setServiceAuthorizations(
|
356
|
+
IAccessManager accessManager,
|
357
|
+
address serviceAddress,
|
358
|
+
RoleId[] memory serviceRoles,
|
359
|
+
RoleId[] memory functionRoles,
|
360
|
+
bytes4[][] memory selectors
|
361
|
+
)
|
307
362
|
internal
|
308
363
|
{
|
309
|
-
|
310
|
-
IRegistryService.FunctionConfig[] memory config = abi.decode(configBytes, (IRegistryService.FunctionConfig[]));
|
311
|
-
|
312
|
-
if(config.length == 0) {
|
313
|
-
revert ConfigMissing();
|
314
|
-
}
|
315
|
-
// always in release
|
316
|
-
_release[version].domains.push(REGISTRY());
|
317
|
-
for(uint idx = 0; idx < config.length; idx++)
|
364
|
+
for(uint idx = 0; idx < functionRoles.length; idx++)
|
318
365
|
{
|
319
|
-
|
320
|
-
|
321
|
-
|
322
|
-
|
323
|
-
if(
|
324
|
-
domain == REGISTRY() ||
|
325
|
-
domain.eqz()
|
326
|
-
) { revert ConfigServiceDomainInvalid(idx, domain); }
|
327
|
-
|
328
|
-
// no overwrite
|
329
|
-
if(_selector[version][domain] > 0) {
|
330
|
-
revert SelectorAlreadyExists(version, domain);
|
331
|
-
}
|
332
|
-
|
333
|
-
_selector[version][domain] = selector;
|
334
|
-
_release[version].domains.push(domain);
|
366
|
+
accessManager.setTargetFunctionRole(
|
367
|
+
serviceAddress,
|
368
|
+
selectors[idx],
|
369
|
+
functionRoles[idx].toInt());
|
335
370
|
}
|
336
|
-
// TODO set when activated?
|
337
|
-
_release[version].createdAt = TimestampLib.blockTimestamp();
|
338
|
-
//_release[version].updatedAt = TimestampLib.blockTimestamp();
|
339
371
|
|
340
|
-
|
372
|
+
for(uint idx = 0; idx < serviceRoles.length; idx++)
|
373
|
+
{
|
374
|
+
accessManager.grantRole(
|
375
|
+
serviceRoles[idx].toInt(),
|
376
|
+
serviceAddress,
|
377
|
+
0);
|
378
|
+
}
|
341
379
|
}
|
342
380
|
}
|
@@ -6,8 +6,8 @@ import {ERC165Checker} from "@openzeppelin/contracts/utils/introspection/ERC165C
|
|
6
6
|
|
7
7
|
import {IRegisterable} from "../shared/IRegisterable.sol";
|
8
8
|
import {IRegistry} from "./IRegistry.sol";
|
9
|
-
import {VersionPart} from "../
|
10
|
-
import {REGISTRY} from "../
|
9
|
+
import {VersionPart} from "../type/Version.sol";
|
10
|
+
import {REGISTRY} from "../type/ObjectType.sol";
|
11
11
|
import {NftOwnable} from "../shared/NftOwnable.sol";
|
12
12
|
|
13
13
|
/// @title contract to register token per GIF major release.
|
@@ -26,21 +26,32 @@ contract TokenRegistry is
|
|
26
26
|
mapping(address token => bool registered) internal _registered;
|
27
27
|
mapping(address token => mapping(VersionPart majorVersion => bool isActive)) internal _active;
|
28
28
|
|
29
|
-
constructor(
|
30
|
-
|
31
|
-
|
29
|
+
constructor(
|
30
|
+
address registry
|
31
|
+
)
|
32
|
+
{
|
33
|
+
initialize(registry);
|
34
|
+
}
|
35
|
+
|
36
|
+
function initialize(address registry)
|
37
|
+
public
|
38
|
+
initializer()
|
39
|
+
{
|
40
|
+
initializeNftOwnable(msg.sender, registry);
|
41
|
+
}
|
32
42
|
|
33
43
|
|
34
44
|
/// @dev link ownership of token registry to nft owner of registry service
|
45
|
+
// TODO latter registry service will get new release, new address, new nft, TokenRegistry will not catch that -> use AccessManaged only for services
|
35
46
|
function linkToNftOwnable(address registryAddress)
|
36
47
|
external
|
37
48
|
onlyOwner
|
38
49
|
{
|
39
50
|
IRegistry registry = IRegistry(registryAddress);
|
40
|
-
// TODO use _latest instead of
|
41
|
-
address registryServiceAddress = registry.getServiceAddress(REGISTRY(), registry.
|
51
|
+
// TODO use _latest instead of _initial -> but _latest is 0 before first release activation
|
52
|
+
address registryServiceAddress = registry.getServiceAddress(REGISTRY(), registry.getNextVersion());
|
42
53
|
|
43
|
-
_linkToNftOwnable(
|
54
|
+
_linkToNftOwnable(registryServiceAddress);
|
44
55
|
}
|
45
56
|
|
46
57
|
/// @dev token state is informative, registry have no clue about used tokens
|
@@ -58,7 +69,7 @@ contract TokenRegistry is
|
|
58
69
|
// verify valid major version
|
59
70
|
// ensure major version increments is one
|
60
71
|
uint256 version = majorVersion.toInt();
|
61
|
-
if (
|
72
|
+
if (!getRegistry().isValidRelease(majorVersion)) {
|
62
73
|
revert TokenMajorVersionInvalid(majorVersion);
|
63
74
|
}
|
64
75
|
|
@@ -91,12 +102,7 @@ contract TokenRegistry is
|
|
91
102
|
revert NotContract(token);
|
92
103
|
}
|
93
104
|
|
94
|
-
// MUST
|
95
|
-
if(ERC165Checker.supportsInterface(token, type(IRegisterable).interfaceId)) {
|
96
|
-
revert NotToken(token);
|
97
|
-
}
|
98
|
-
|
99
|
-
// MUST have decimals > 0
|
105
|
+
// MUST have decimals > 0 (indicator that this is in fact an erc20 token)
|
100
106
|
IERC20Metadata erc20 = IERC20Metadata(token);
|
101
107
|
if(erc20.decimals() == 0) {
|
102
108
|
revert TokenDecimalsZero();
|
@@ -0,0 +1,13 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {AccessManagerUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagerUpgradeable.sol";
|
5
|
+
|
6
|
+
|
7
|
+
contract AccessManagerUpgradeableInitializeable is AccessManagerUpgradeable {
|
8
|
+
|
9
|
+
function initialize(address initialAdmin) initializer public {
|
10
|
+
__AccessManager_init(initialAdmin);
|
11
|
+
}
|
12
|
+
|
13
|
+
}
|