@etherisc/gif-next 0.0.2-e769e2e-077 → 0.0.2-e802d97-713
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 +2 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +19 -13
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +79 -73
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +114 -56
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +11 -5
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +7 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +2 -2
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +25 -6
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +12 -22
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +47 -20
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +708 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +126 -30
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +195 -64
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +77 -63
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +104 -34
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +246 -104
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +2 -2
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +8 -116
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
- package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +10 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +759 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +662 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +1146 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +997 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +718 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +55 -41
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +102 -40
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +7 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +11 -5
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +22 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +18 -12
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +56 -35
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +95 -37
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +39 -25
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +96 -34
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +81 -67
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +115 -53
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +7 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +7 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +7 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +7 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +11 -5
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/product/IProductService.sol/IProductService.json +7 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +59 -45
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +104 -42
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +69 -55
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +109 -47
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +18 -12
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +25 -19
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +87 -29
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +150 -53
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +187 -67
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +328 -103
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +407 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +197 -72
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +87 -39
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +752 -148
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +2 -2
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +185 -135
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +1193 -0
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +1715 -0
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +1728 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +1806 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +1824 -0
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +18 -12
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +92 -63
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +102 -46
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +7 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +1562 -0
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +1600 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +11 -5
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +14 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +11 -5
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +0 -10
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +7 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +21 -3
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +7 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +7 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +18 -12
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +10 -20
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +6 -6
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +306 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +13 -7
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +31 -13
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +64 -16
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +15 -9
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -2
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +7 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +2 -2
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +424 -593
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +497 -49
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +444 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +598 -627
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +149 -48
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +592 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +593 -74
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +119 -29
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2189 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +571 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +68 -4
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +40 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +2 -2
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +2 -2
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +28 -4
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +15 -2
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +2 -2
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +2 -2
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +2 -2
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +76 -2
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +17 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +2 -2
- package/contracts/distribution/Distribution.sol +2 -4
- package/contracts/distribution/DistributionService.sol +3 -2
- package/contracts/distribution/DistributionServiceManager.sol +9 -18
- package/contracts/distribution/IDistributionComponent.sol +1 -1
- package/contracts/distribution/IDistributionService.sol +1 -1
- package/contracts/instance/IInstance.sol +11 -6
- package/contracts/instance/IInstanceService.sol +3 -5
- package/contracts/instance/Instance.sol +29 -21
- package/contracts/instance/InstanceAdmin.sol +331 -0
- package/contracts/instance/InstanceAuthorizationsLib.sol +192 -151
- package/contracts/instance/InstanceReader.sol +30 -6
- package/contracts/instance/InstanceService.sol +69 -55
- package/contracts/instance/InstanceServiceManager.sol +10 -20
- package/contracts/instance/InstanceStore.sol +64 -42
- package/contracts/instance/base/BalanceStore.sol +1 -1
- package/contracts/instance/base/ObjectCounter.sol +21 -0
- package/contracts/instance/module/IAccess.sol +2 -10
- package/contracts/mock/Dip.sol +26 -0
- package/contracts/oracle/IOracle.sol +20 -0
- package/contracts/oracle/IOracleComponent.sol +32 -0
- package/contracts/oracle/IOracleService.sol +65 -0
- package/contracts/oracle/Oracle.sol +145 -0
- package/contracts/oracle/OracleService.sol +277 -0
- package/contracts/oracle/OracleServiceManager.sol +42 -0
- package/contracts/pool/BundleService.sol +6 -23
- package/contracts/pool/BundleServiceManager.sol +9 -18
- package/contracts/pool/IBundleService.sol +1 -1
- package/contracts/pool/IPoolService.sol +4 -1
- package/contracts/pool/PoolService.sol +45 -13
- package/contracts/pool/PoolServiceManager.sol +9 -18
- package/contracts/product/ApplicationService.sol +6 -5
- package/contracts/product/ApplicationServiceManager.sol +9 -6
- package/contracts/product/ClaimService.sol +13 -7
- package/contracts/product/ClaimServiceManager.sol +9 -6
- package/contracts/product/IApplicationService.sol +1 -1
- package/contracts/product/IClaimService.sol +7 -1
- package/contracts/product/IPolicyService.sol +1 -1
- package/contracts/product/IPricingService.sol +1 -1
- package/contracts/product/IProductService.sol +1 -1
- package/contracts/product/PolicyService.sol +10 -6
- package/contracts/product/PolicyServiceManager.sol +9 -21
- package/contracts/product/PricingService.sol +10 -9
- package/contracts/product/PricingServiceManager.sol +9 -18
- package/contracts/product/Product.sol +1 -1
- package/contracts/product/ProductService.sol +7 -5
- package/contracts/product/ProductServiceManager.sol +9 -21
- package/contracts/registry/ChainNft.sol +1 -0
- package/contracts/registry/IRegistry.sol +37 -24
- package/contracts/registry/IRegistryService.sol +26 -36
- package/contracts/registry/Registry.sol +164 -117
- package/contracts/registry/RegistryAdmin.sol +237 -0
- package/contracts/registry/RegistryService.sol +22 -83
- package/contracts/registry/RegistryServiceManager.sol +21 -23
- package/contracts/registry/ReleaseManager.sol +448 -223
- package/contracts/registry/TokenRegistry.sol +187 -59
- package/contracts/shared/AccessManagerCustom.sol +736 -0
- package/contracts/shared/AccessManagerExtended.sol +470 -0
- package/contracts/shared/AccessManagerExtendedInitializeable.sol +13 -0
- package/contracts/shared/AccessManagerExtendedWithDisable.sol +137 -0
- package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +14 -0
- package/contracts/shared/Component.sol +8 -13
- package/contracts/shared/ComponentService.sol +35 -13
- package/contracts/shared/ComponentVerifyingService.sol +13 -7
- package/contracts/shared/ERC165.sol +1 -1
- package/contracts/shared/IAccessManagerExtended.sol +74 -0
- package/contracts/shared/IAccessManagerExtendedWithDisable.sol +18 -0
- package/contracts/shared/IComponent.sol +3 -7
- package/contracts/shared/IComponentService.sol +11 -0
- package/contracts/shared/IKeyValueStore.sol +1 -1
- package/contracts/shared/INftOwnable.sol +1 -1
- package/contracts/shared/IPolicyHolder.sol +6 -1
- package/contracts/shared/IService.sol +1 -1
- package/contracts/shared/InitializableCustom.sol +177 -0
- package/contracts/shared/InstanceLinkedComponent.sol +1 -2
- package/contracts/shared/KeyValueStore.sol +24 -66
- package/contracts/shared/Lifecycle.sol +11 -2
- package/contracts/shared/NftIdSetManager.sol +65 -0
- package/contracts/shared/NftOwnable.sol +2 -13
- package/contracts/shared/PolicyHolder.sol +21 -13
- package/contracts/shared/ProxyManager.sol +31 -1
- package/contracts/shared/Service.sol +1 -1
- package/contracts/staking/IStaking.sol +127 -36
- package/contracts/staking/IStakingService.sol +83 -39
- package/contracts/staking/StakeManagerLib.sol +179 -0
- package/contracts/staking/Staking.sol +432 -93
- package/contracts/staking/StakingManager.sol +22 -14
- package/contracts/staking/StakingReader.sol +187 -0
- package/contracts/staking/StakingService.sol +245 -39
- package/contracts/staking/StakingServiceManager.sol +8 -4
- package/contracts/staking/StakingStore.sol +572 -0
- package/contracts/staking/TargetManagerLib.sol +207 -0
- package/contracts/type/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +15 -1
- package/contracts/type/Blocknumber.sol +14 -2
- package/contracts/type/Fee.sol +1 -1
- package/contracts/type/NftId.sol +9 -4
- package/contracts/type/NftIdSet.sol +1 -1
- package/contracts/type/ObjectType.sol +12 -9
- package/contracts/type/Referral.sol +1 -1
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/type/RiskId.sol +1 -1
- package/contracts/type/RoleId.sol +16 -8
- package/contracts/type/Seconds.sol +27 -0
- package/contracts/type/StateId.sol +27 -2
- package/contracts/type/Timestamp.sol +6 -2
- package/contracts/type/Version.sol +1 -1
- package/package.json +3 -3
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1348
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -308
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
- package/contracts/instance/InstanceAccessManager.sol +0 -543
- package/contracts/registry/RegistryAccessManager.sol +0 -213
- package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +0 -13
@@ -1,265 +1,370 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
+
import {Create2} from "@openzeppelin/contracts/utils/Create2.sol";
|
5
|
+
import {Clones} from "@openzeppelin/contracts/proxy/Clones.sol";
|
6
|
+
import {IAccessManager} from "@openzeppelin/contracts/access/manager/IAccessManager.sol";
|
7
|
+
import {Initializable} from "@openzeppelin/contracts/proxy/utils/Initializable.sol";
|
4
8
|
import {AccessManaged} from "@openzeppelin/contracts/access/manager/AccessManaged.sol";
|
9
|
+
import {Math} from "@openzeppelin/contracts/utils/math/Math.sol";
|
5
10
|
|
6
11
|
import {NftId} from "../type/NftId.sol";
|
7
|
-
import {RoleId} from "../type/RoleId.sol";
|
8
|
-
import {ObjectType, ObjectTypeLib,
|
12
|
+
import {RoleId, ADMIN_ROLE, PUBLIC_ROLE} from "../type/RoleId.sol";
|
13
|
+
import {ObjectType, ObjectTypeLib, RELEASE, REGISTRY, SERVICE, STAKING} from "../type/ObjectType.sol";
|
14
|
+
import {Version, VersionLib, VersionPart, VersionPartLib} from "../type/Version.sol";
|
15
|
+
import {Timestamp, TimestampLib, zeroTimestamp, ltTimestamp} from "../type/Timestamp.sol";
|
16
|
+
import {Seconds, SecondsLib} from "../type/Seconds.sol";
|
17
|
+
import {StateId, INITIAL, SCHEDULED, DEPLOYING, ACTIVE} from "../type/StateId.sol";
|
9
18
|
import {Version, VersionLib, VersionPart, VersionPartLib} from "../type/Version.sol";
|
10
|
-
import {Timestamp, TimestampLib} from "../type/Timestamp.sol";
|
11
19
|
|
20
|
+
import {IService} from "../shared/IService.sol";
|
21
|
+
import {AccessManagerExtendedWithDisableInitializeable} from "../shared/AccessManagerExtendedWithDisableInitializeable.sol";
|
22
|
+
import {ILifecycle} from "../shared/ILifecycle.sol";
|
23
|
+
import {INftOwnable} from "../shared/INftOwnable.sol";
|
12
24
|
import {IRegisterable} from "../shared/IRegisterable.sol";
|
25
|
+
|
13
26
|
import {IRegistry} from "./IRegistry.sol";
|
27
|
+
import {IRegistryLinked} from "../shared/IRegistryLinked.sol";
|
14
28
|
import {IRegistryService} from "./IRegistryService.sol";
|
15
|
-
import {
|
16
|
-
import {IStaking} from "../staking/IStaking.sol";
|
17
|
-
|
29
|
+
import {RegistryAdmin} from "./RegistryAdmin.sol";
|
18
30
|
import {Registry} from "./Registry.sol";
|
19
|
-
import {RegistryAccessManager} from "./RegistryAccessManager.sol";
|
20
|
-
import {ServiceAuthorizationsLib} from "./ServiceAuthorizationsLib.sol";
|
21
31
|
import {TokenRegistry} from "./TokenRegistry.sol";
|
32
|
+
import {ServiceAuthorizationsLib} from "./ServiceAuthorizationsLib.sol";
|
22
33
|
|
23
|
-
|
34
|
+
|
35
|
+
contract ReleaseManager is
|
36
|
+
AccessManaged,
|
37
|
+
ILifecycle,
|
38
|
+
IRegistryLinked
|
24
39
|
{
|
25
40
|
using ObjectTypeLib for ObjectType;
|
26
41
|
|
27
|
-
|
42
|
+
uint256 public constant INITIAL_GIF_VERSION = 3;
|
43
|
+
|
44
|
+
event LogReleaseCreation(VersionPart version, bytes32 salt, AccessManagerExtendedWithDisableInitializeable accessManager);
|
28
45
|
event LogReleaseActivation(VersionPart version);
|
29
46
|
|
47
|
+
// constructor
|
48
|
+
error ErrorReleaseManagerNotRegistry(Registry registry);
|
49
|
+
|
30
50
|
// createNextRelease
|
31
|
-
error
|
32
|
-
error UnexpectedServiceAuthority(address expected, address found);
|
51
|
+
error ErrorReleaseManagerReleaseCreationDisallowed(StateId currentStateId);
|
33
52
|
|
53
|
+
// prepareRelease
|
54
|
+
error ErrorReleaseManagerReleasePreparationDisallowed(StateId currentStateId);
|
55
|
+
error ErrorReleaseManagerReleaseAlreadyPrepared(VersionPart version);
|
56
|
+
|
34
57
|
// register staking
|
35
|
-
error ErrorReleaseManagerStakingAlreadySet(address stakingAddress);
|
58
|
+
//error ErrorReleaseManagerStakingAlreadySet(address stakingAddress);
|
36
59
|
|
37
60
|
// registerService
|
38
|
-
error
|
61
|
+
error ErrorReleaseManagerNoServiceRegistrationExpected();
|
62
|
+
error ErrorReleaseManagerServiceRegistrationDisallowed(StateId currentStateId);
|
63
|
+
error ErrorReleaseManagerNotService(IService service);
|
64
|
+
error ErrorReleaseManagerServiceAddressInvalid(IService given, address expected);
|
39
65
|
|
40
66
|
// activateNextRelease
|
41
|
-
error
|
42
|
-
error
|
67
|
+
error ErrorReleaseManagerReleaseActivationDisallowed(StateId currentStateId);
|
68
|
+
error ErrorReleaseManagerReleaseNotCreated(VersionPart releaseVersion);
|
69
|
+
error ErrorReleaseManagerReleaseRegistrationNotFinished(VersionPart releaseVersion, uint awaitingRegistration);
|
70
|
+
error ErrorReleaseManagerReleaseAlreadyActivated(VersionPart releaseVersion);
|
43
71
|
|
44
|
-
//
|
45
|
-
error
|
46
|
-
error
|
47
|
-
error UnexpectedRegisterableType(ObjectType expected, ObjectType found);
|
48
|
-
error NotRegisterableOwner(address expectedOwner, address actualOwner);
|
49
|
-
error SelfRegistration();
|
50
|
-
error RegisterableOwnerIsRegistered();
|
72
|
+
// disableRelease
|
73
|
+
error ErrorReleaseManagerReleaseNotActivated(VersionPart releaseVersion);
|
74
|
+
error ErrorReleaseManagerReleaseAlreadyDisabled(VersionPart releaseVersion);
|
51
75
|
|
52
76
|
// _verifyService
|
53
|
-
error
|
54
|
-
error
|
55
|
-
|
56
|
-
//
|
57
|
-
error
|
58
|
-
error
|
59
|
-
error
|
60
|
-
error
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
77
|
+
error ErrorReleaseManagerServiceReleaseAuthorityMismatch(IService service, address serviceAuthority, address releaseAuthority);
|
78
|
+
error ErrorReleaseManagerServiceReleaseVersionMismatch(IService service, VersionPart serviceVersion, VersionPart releaseVersion);
|
79
|
+
|
80
|
+
// _verifyServiceInfo
|
81
|
+
error ErrorReleaseManagerServiceInfoAddressInvalid(IService service, address expected);
|
82
|
+
error ErrorReleaseManagerServiceInfoInterceptorInvalid(IService service, bool isInterceptor);
|
83
|
+
error ErrorReleaseManagerServiceInfoTypeInvalid(IService service, ObjectType expected, ObjectType found);
|
84
|
+
error ErrorReleaseManagerServiceInfoOwnerInvalid(IService service, address expected, address found);
|
85
|
+
error ErrorReleaseManagerServiceSelfRegistration(IService service);
|
86
|
+
error ErrorReleaseManagerServiceOwnerRegistered(IService service, address owner);
|
87
|
+
|
88
|
+
// _verifyReleaseAuthorizations
|
89
|
+
error ErrorReleaseManagerReleaseEmpty();
|
90
|
+
error ErrorReleaseManagerReleaseServiceRoleInvalid(uint serviceIdx, address service, RoleId role);
|
91
|
+
|
92
|
+
Seconds public constant MIN_DISABLE_DELAY = Seconds.wrap(60 * 24 * 365); // 1 year
|
93
|
+
|
94
|
+
RegistryAdmin public immutable _admin;
|
95
|
+
address public immutable _releaseAccessManagerCodeAddress;
|
96
|
+
Registry public immutable _registry;
|
97
|
+
IRegisterable private _staking;
|
98
|
+
address private _stakingOwner;
|
99
|
+
|
100
|
+
mapping(VersionPart version => AccessManagerExtendedWithDisableInitializeable accessManager) internal _releaseAccessManager;
|
101
|
+
mapping(VersionPart version => IRegistry.ReleaseInfo info) internal _releaseInfo;
|
102
|
+
mapping(address registryService => VersionPart version) _releaseVersionByAddress;
|
103
|
+
|
104
|
+
VersionPart immutable internal _initial;// first active version
|
105
|
+
VersionPart internal _latest; // latest active version
|
106
|
+
VersionPart internal _next; // version to create and activate
|
107
|
+
StateId internal _state; // current state of release manager
|
108
|
+
|
109
|
+
uint256 internal _awaitingRegistration; // "services left to register" counter
|
110
|
+
|
111
|
+
// deployer of this contract must be gif admin
|
112
|
+
constructor(Registry registry)
|
113
|
+
AccessManaged(msg.sender)
|
114
|
+
{
|
115
|
+
// TODO move this part to RegistryLinked constructor
|
116
|
+
if(!_isRegistry(address(registry))) {
|
117
|
+
revert ErrorReleaseManagerNotRegistry(registry);
|
118
|
+
}
|
70
119
|
|
71
|
-
|
120
|
+
_registry = registry;
|
121
|
+
setAuthority(_registry.getAuthority());
|
122
|
+
_admin = RegistryAdmin(_registry.getRegistryAdminAddress());
|
72
123
|
|
73
|
-
|
74
|
-
|
124
|
+
_initial = VersionPartLib.toVersionPart(INITIAL_GIF_VERSION);
|
125
|
+
_next = VersionPartLib.toVersionPart(INITIAL_GIF_VERSION - 1);
|
126
|
+
_state = getInitialState(RELEASE());
|
127
|
+
|
128
|
+
AccessManagerExtendedWithDisableInitializeable masterReleaseAccessManager = new AccessManagerExtendedWithDisableInitializeable();
|
129
|
+
masterReleaseAccessManager.initialize(_registry.NFT_LOCK_ADDRESS(), VersionLib.toVersionPart(0));
|
130
|
+
//masterReleaseAccessManager.disable();
|
131
|
+
_releaseAccessManagerCodeAddress = address(masterReleaseAccessManager);
|
132
|
+
}
|
75
133
|
|
76
|
-
|
134
|
+
/// @dev skips previous release if was not activated
|
135
|
+
/// sets release manager into state SCHEDULED
|
136
|
+
function createNextRelease()
|
137
|
+
external
|
138
|
+
restricted() // GIF_ADMIN_ROLE
|
139
|
+
returns(VersionPart)
|
140
|
+
{
|
141
|
+
if (!isValidTransition(RELEASE(), _state, SCHEDULED())) {
|
142
|
+
revert ErrorReleaseManagerReleaseCreationDisallowed(_state);
|
143
|
+
}
|
77
144
|
|
78
|
-
|
145
|
+
_next = VersionPartLib.toVersionPart(_next.toInt() + 1);
|
146
|
+
_awaitingRegistration = 0;
|
147
|
+
_state = SCHEDULED();
|
79
148
|
|
80
|
-
|
149
|
+
return _next;
|
150
|
+
}
|
81
151
|
|
82
|
-
|
83
|
-
|
84
|
-
|
152
|
+
// TODO order of events
|
153
|
+
function prepareNextRelease(
|
154
|
+
address[] memory addresses,
|
155
|
+
string[] memory names,
|
156
|
+
RoleId[][] memory serviceRoles,
|
157
|
+
string[][] memory serviceRoleNames,
|
158
|
+
RoleId[][] memory functionRoles,
|
159
|
+
string[][] memory functionRoleNames,
|
160
|
+
bytes4[][][] memory selectors,
|
161
|
+
bytes32 salt
|
85
162
|
)
|
86
|
-
|
163
|
+
external
|
164
|
+
restricted() // GIF_MANAGER_ROLE
|
165
|
+
returns(
|
166
|
+
address releaseAccessManagerAddress,
|
167
|
+
VersionPart version,
|
168
|
+
bytes32 releaseSalt
|
169
|
+
)
|
87
170
|
{
|
88
|
-
|
171
|
+
version = getNextVersion();
|
89
172
|
|
90
|
-
|
173
|
+
// ensures unique salt
|
174
|
+
releaseSalt = keccak256(
|
175
|
+
bytes.concat(
|
176
|
+
bytes32(version.toInt()),
|
177
|
+
salt));
|
91
178
|
|
92
|
-
|
93
|
-
|
179
|
+
releaseAccessManagerAddress = Clones.cloneDeterministic(_releaseAccessManagerCodeAddress, releaseSalt);
|
180
|
+
AccessManagerExtendedWithDisableInitializeable releaseAccessManager = AccessManagerExtendedWithDisableInitializeable(releaseAccessManagerAddress);
|
181
|
+
releaseAccessManager.initialize(address(this), version);
|
182
|
+
|
183
|
+
if (!isValidTransition(RELEASE(), _state, DEPLOYING())) {
|
184
|
+
revert ErrorReleaseManagerReleasePreparationDisallowed(_state);
|
185
|
+
}
|
94
186
|
|
95
|
-
|
96
|
-
_tokenRegistry = new TokenRegistry(address(_registry));
|
187
|
+
_verifyReleaseAuthorizations(addresses, serviceRoles, functionRoles, selectors);
|
97
188
|
|
98
|
-
|
189
|
+
if(_awaitingRegistration > 0) {
|
190
|
+
revert ErrorReleaseManagerReleaseAlreadyPrepared(version);
|
191
|
+
}
|
192
|
+
// TODO instead of copying just set ServiceAuthorizationsLib for release and array of domains???
|
193
|
+
_releaseInfo[version].version = version;
|
194
|
+
_releaseInfo[version].salt = releaseSalt;
|
195
|
+
_releaseInfo[version].addresses = addresses;
|
196
|
+
_releaseInfo[version].names = names;
|
197
|
+
_releaseInfo[version].serviceRoles = serviceRoles;
|
198
|
+
_releaseInfo[version].serviceRoleNames = serviceRoleNames;
|
199
|
+
_releaseInfo[version].functionRoles = functionRoles;
|
200
|
+
_releaseInfo[version].functionRoleNames = functionRoleNames;
|
201
|
+
_releaseInfo[version].selectors = selectors;
|
202
|
+
_awaitingRegistration = addresses.length;
|
203
|
+
_state = DEPLOYING();
|
204
|
+
_releaseAccessManager[version] = releaseAccessManager;
|
205
|
+
|
206
|
+
emit LogReleaseCreation(version, releaseSalt, releaseAccessManager);
|
99
207
|
}
|
100
208
|
|
101
|
-
|
102
|
-
|
103
|
-
address stakingOwner
|
104
|
-
)
|
209
|
+
|
210
|
+
function registerService(IService service)
|
105
211
|
external
|
106
|
-
restricted //
|
212
|
+
restricted // GIF_MANAGER_ROLE
|
107
213
|
returns(NftId nftId)
|
108
214
|
{
|
109
|
-
|
110
|
-
|
111
|
-
|
215
|
+
if (!isValidTransition(RELEASE(), _state, DEPLOYING())) {
|
216
|
+
revert ErrorReleaseManagerServiceRegistrationDisallowed(_state);
|
217
|
+
}
|
112
218
|
|
113
|
-
|
114
|
-
|
115
|
-
|
219
|
+
(
|
220
|
+
IRegistry.ObjectInfo memory info,
|
221
|
+
ObjectType domain,
|
222
|
+
VersionPart version
|
223
|
+
) = _verifyService(service);
|
116
224
|
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
function createNextRelease()
|
122
|
-
external
|
123
|
-
restricted // GIF_ADMIN_ROLE
|
124
|
-
{
|
125
|
-
// allow to register new registry service for next version
|
126
|
-
// TODO check/test: assignment to _next likely missing ...
|
127
|
-
VersionPartLib.toVersionPart(_next.toInt() + 1);
|
225
|
+
// redundant with state var
|
226
|
+
if (_awaitingRegistration == 0) {
|
227
|
+
revert ErrorReleaseManagerNoServiceRegistrationExpected();
|
228
|
+
}
|
128
229
|
|
129
|
-
|
130
|
-
|
230
|
+
uint serviceIdx = _awaitingRegistration - 1;
|
231
|
+
address serviceAddress = _releaseInfo[version].addresses[serviceIdx];
|
232
|
+
// TODO temp, while typescript addresses computation is not implemented
|
233
|
+
/*if(address(service) != serviceAddress) {
|
234
|
+
revert ErrorReleaseManagerServiceAddressInvalid(service, serviceAddress);
|
235
|
+
}*/
|
236
|
+
|
237
|
+
_setServiceAuthorizations(
|
238
|
+
_releaseAccessManager[version],
|
239
|
+
// TODO temp, while typescript addresses computation is not implemented
|
240
|
+
address(service),//serviceAddress,
|
241
|
+
_releaseInfo[version].names[serviceIdx],
|
242
|
+
_releaseInfo[version].serviceRoles[serviceIdx],
|
243
|
+
_releaseInfo[version].serviceRoleNames[serviceIdx],
|
244
|
+
_releaseInfo[version].functionRoles[serviceIdx],
|
245
|
+
_releaseInfo[version].functionRoleNames[serviceIdx],
|
246
|
+
_releaseInfo[version].selectors[serviceIdx]);
|
247
|
+
|
248
|
+
// TODO decide for one of the approaches
|
249
|
+
// // service to service authorization
|
250
|
+
// ServiceAuthorizationsLib.ServiceAuthorization memory authz = ServiceAuthorizationsLib.getAuthorizations(domain);
|
251
|
+
// for(uint8 idx = 0; idx < authz.authorizedRole.length; idx++) {
|
252
|
+
// _accessManager.setTargetFunctionRole(
|
253
|
+
// address(service),
|
254
|
+
// authz.authorizedSelectors[idx],
|
255
|
+
// authz.authorizedRole[idx]);
|
256
|
+
// }
|
257
|
+
|
258
|
+
_awaitingRegistration = serviceIdx;
|
259
|
+
// TODO end state depends on (_awaitingRegistration == 0)
|
260
|
+
_state = DEPLOYING();
|
261
|
+
|
262
|
+
// checked in registry
|
263
|
+
_releaseInfo[version].domains.push(domain);
|
264
|
+
|
265
|
+
nftId = _registry.registerService(info, version, domain);
|
131
266
|
|
132
|
-
|
267
|
+
service.linkToRegisteredNftId();
|
133
268
|
}
|
134
269
|
|
270
|
+
|
135
271
|
function activateNextRelease()
|
136
272
|
external
|
137
273
|
restricted // GIF_ADMIN_ROLE
|
138
274
|
{
|
275
|
+
if (!isValidTransition(RELEASE(), _state, ACTIVE())) {
|
276
|
+
revert ErrorReleaseManagerReleaseActivationDisallowed(_state);
|
277
|
+
}
|
278
|
+
|
139
279
|
VersionPart version = _next;
|
140
280
|
address service = _registry.getServiceAddress(REGISTRY(), version);
|
141
281
|
|
142
|
-
// release
|
282
|
+
// release exists, registry service is a MUST
|
283
|
+
//if(_releaseAccessManager[version] == address(0)) {
|
143
284
|
if(service == address(0)) {
|
144
|
-
revert
|
285
|
+
revert ErrorReleaseManagerReleaseNotCreated(version);
|
145
286
|
}
|
146
287
|
|
147
288
|
// release fully deployed
|
148
289
|
if(_awaitingRegistration > 0) {
|
149
|
-
revert
|
290
|
+
revert ErrorReleaseManagerReleaseRegistrationNotFinished(version, _awaitingRegistration);
|
150
291
|
}
|
151
292
|
|
152
|
-
//
|
293
|
+
// release is not activated
|
294
|
+
if(_releaseInfo[version].activatedAt.gtz()) {
|
295
|
+
revert ErrorReleaseManagerReleaseAlreadyActivated(version);
|
296
|
+
}
|
153
297
|
|
154
298
|
_latest = version;
|
299
|
+
_state = ACTIVE();
|
155
300
|
|
156
|
-
|
157
|
-
|
301
|
+
_releaseVersionByAddress[service] = version;
|
302
|
+
_releaseInfo[version].activatedAt = TimestampLib.blockTimestamp();
|
158
303
|
|
159
304
|
emit LogReleaseActivation(version);
|
160
305
|
}
|
161
306
|
|
162
|
-
//
|
163
|
-
|
164
|
-
// callable once per release after release creation
|
165
|
-
// can not register regular services
|
166
|
-
function registerRegistryService(IRegistryService service)
|
307
|
+
// release becomes disabled after delay expiration (can be reenabled before that)
|
308
|
+
function disableRelease(VersionPart version, Seconds disableDelay)
|
167
309
|
external
|
168
|
-
restricted //
|
169
|
-
returns(NftId nftId)
|
310
|
+
restricted // GIF_ADMIN_ROLE
|
170
311
|
{
|
171
|
-
|
172
|
-
|
312
|
+
// release was activated
|
313
|
+
if(_releaseInfo[version].activatedAt.eqz()) {
|
314
|
+
revert ErrorReleaseManagerReleaseNotActivated(version);
|
173
315
|
}
|
174
316
|
|
175
|
-
//
|
176
|
-
|
177
|
-
|
178
|
-
revert UnexpectedServiceAuthority(
|
179
|
-
authority(),
|
180
|
-
serviceAuthority);
|
317
|
+
// release not disabled already
|
318
|
+
if(_releaseInfo[version].disabledAt.gtz()) {
|
319
|
+
revert ErrorReleaseManagerReleaseAlreadyDisabled(version);
|
181
320
|
}
|
182
321
|
|
183
|
-
|
322
|
+
disableDelay = SecondsLib.toSeconds(Math.max(disableDelay.toInt(), MIN_DISABLE_DELAY.toInt()));
|
184
323
|
|
185
|
-
|
186
|
-
ObjectType domain = REGISTRY();
|
187
|
-
_verifyService(service, majorVersion, domain);
|
188
|
-
_createRelease(service.getFunctionConfigs());
|
189
|
-
|
190
|
-
nftId = _registry.registerService(info, majorVersion, domain);
|
324
|
+
_releaseAccessManager[version].disable(disableDelay);
|
191
325
|
|
192
|
-
|
193
|
-
service.linkToRegisteredNftId();
|
326
|
+
_releaseInfo[version].disabledAt = TimestampLib.blockTimestamp().addSeconds(disableDelay);
|
194
327
|
}
|
195
|
-
|
196
|
-
|
197
|
-
// TODO removing service from release? -> set _active to false forever, but keep all other records?
|
198
|
-
function registerService(IService service)
|
328
|
+
|
329
|
+
function enableRelease(VersionPart version)
|
199
330
|
external
|
200
|
-
restricted //
|
201
|
-
returns(NftId nftId)
|
331
|
+
restricted // GIF_ADMIN_ROLE
|
202
332
|
{
|
203
|
-
|
204
|
-
|
205
|
-
|
333
|
+
// release was disabled
|
334
|
+
//if(_releaseInfo[version].disabledAt.eqz()) {
|
335
|
+
// revert ErrorReleaseManagerReleaseAlreadyEnabled(version);
|
336
|
+
//}
|
206
337
|
|
207
|
-
|
208
|
-
|
209
|
-
ObjectType domain = _release[majorVersion].domains[_awaitingRegistration];// reversed registration order of services specified in RegistryService config
|
210
|
-
_verifyService(service, majorVersion, domain);
|
211
|
-
|
212
|
-
// setup and grant unique role if service does registrations
|
213
|
-
bytes4[] memory selectors = _selectors[majorVersion][domain];
|
214
|
-
address registryService = _registry.getServiceAddress(REGISTRY(), majorVersion);
|
215
|
-
if(selectors.length > 0) {
|
216
|
-
_accessManager.setAndGrantUniqueRole(
|
217
|
-
address(service),
|
218
|
-
registryService,
|
219
|
-
selectors);
|
220
|
-
}
|
338
|
+
// reverts if disable delay expired
|
339
|
+
_releaseAccessManager[version].enable();
|
221
340
|
|
222
|
-
|
223
|
-
ServiceAuthorizationsLib.ServiceAuthorization memory authz = ServiceAuthorizationsLib.getAuthorizations(domain);
|
224
|
-
for(uint8 idx = 0; idx < authz.authorizedRole.length; idx++) {
|
225
|
-
_accessManager.setTargetFunctionRole(
|
226
|
-
address(service),
|
227
|
-
authz.authorizedSelectors[idx],
|
228
|
-
authz.authorizedRole[idx]);
|
229
|
-
}
|
230
|
-
|
231
|
-
_awaitingRegistration--;
|
232
|
-
|
233
|
-
nftId = _registry.registerService(info, majorVersion, domain);
|
234
|
-
|
235
|
-
// external call
|
236
|
-
service.linkToRegisteredNftId();
|
341
|
+
_releaseInfo[version].disabledAt = zeroTimestamp();
|
237
342
|
}
|
238
343
|
|
239
344
|
//--- view functions ----------------------------------------------------//
|
240
345
|
|
241
|
-
function
|
242
|
-
|
243
|
-
|
346
|
+
function predictDeterministicAddress(
|
347
|
+
address implementation,
|
348
|
+
bytes32 salt,
|
349
|
+
address deployer
|
350
|
+
) external pure returns (address predicted) {
|
351
|
+
return Clones.predictDeterministicAddress(implementation, salt, deployer);
|
244
352
|
}
|
245
353
|
|
246
|
-
function
|
247
|
-
|
248
|
-
return
|
354
|
+
function isActiveRegistryService(address service) external view returns(bool) {
|
355
|
+
VersionPart version = _releaseVersionByAddress[service];
|
356
|
+
return isActiveRelease(version);
|
249
357
|
}
|
250
358
|
|
251
|
-
function
|
252
|
-
|
253
|
-
return address(_registry);
|
359
|
+
function isActiveRelease(VersionPart version) public view returns(bool) {
|
360
|
+
return _releaseInfo[version].activatedAt.gtz();
|
254
361
|
}
|
255
362
|
|
256
|
-
function getReleaseInfo(VersionPart version) external view returns(IRegistry.ReleaseInfo memory)
|
257
|
-
|
258
|
-
return _release[version];
|
363
|
+
function getReleaseInfo(VersionPart version) external view returns(IRegistry.ReleaseInfo memory) {
|
364
|
+
return _releaseInfo[version];
|
259
365
|
}
|
260
366
|
|
261
|
-
function getNextVersion() public view returns(VersionPart)
|
262
|
-
{
|
367
|
+
function getNextVersion() public view returns(VersionPart) {
|
263
368
|
return _next;
|
264
369
|
}
|
265
370
|
|
@@ -271,105 +376,225 @@ contract ReleaseManager is AccessManaged
|
|
271
376
|
return _initial;
|
272
377
|
}
|
273
378
|
|
274
|
-
|
379
|
+
function getState() external view returns (StateId stateId) {
|
380
|
+
return _state;
|
381
|
+
}
|
275
382
|
|
276
|
-
function
|
277
|
-
|
278
|
-
|
279
|
-
|
383
|
+
function getRemainingServicesToRegister() external view returns (uint256 services) {
|
384
|
+
return _awaitingRegistration;
|
385
|
+
}
|
386
|
+
|
387
|
+
function getReleaseAccessManager(VersionPart version) external view returns(AccessManagerExtendedWithDisableInitializeable) {
|
388
|
+
return _releaseAccessManager[version];
|
389
|
+
}
|
390
|
+
// TODO tokenr registry knows nothing about adfmin, only registry
|
391
|
+
function getRegistryAdmin() external view returns (address) {
|
392
|
+
return address(_admin);
|
393
|
+
}
|
394
|
+
|
395
|
+
//--- IRegistryLinked ------------------------------------------------------//
|
396
|
+
|
397
|
+
function getRegistry() external view returns (IRegistry) {
|
398
|
+
return _registry;
|
399
|
+
}
|
400
|
+
|
401
|
+
//--- ILifecycle -----------------------------------------------------------//
|
402
|
+
|
403
|
+
function hasLifecycle(ObjectType objectType) external pure returns (bool) { return objectType == RELEASE(); }
|
404
|
+
|
405
|
+
function getInitialState(ObjectType objectType) public pure returns (StateId stateId) {
|
406
|
+
if (objectType == RELEASE()) {
|
407
|
+
stateId = INITIAL();
|
408
|
+
}
|
409
|
+
}
|
410
|
+
|
411
|
+
function isValidTransition(
|
412
|
+
ObjectType objectType,
|
413
|
+
StateId fromId,
|
414
|
+
StateId toId
|
280
415
|
)
|
416
|
+
public
|
417
|
+
pure
|
418
|
+
returns (bool isValid)
|
419
|
+
{
|
420
|
+
if (objectType != RELEASE()) { return false; }
|
421
|
+
|
422
|
+
if (fromId == INITIAL() && toId == SCHEDULED()) { return true; }
|
423
|
+
if (fromId == SCHEDULED() && toId == DEPLOYING()) { return true; }
|
424
|
+
if (fromId == DEPLOYING() && toId == SCHEDULED()) { return true; }
|
425
|
+
if (fromId == DEPLOYING() && toId == DEPLOYING()) { return true; }
|
426
|
+
if (fromId == DEPLOYING() && toId == ACTIVE()) { return true; }
|
427
|
+
// TODO active -> scheduled missing, add tests to cover this and more scenarios (#358)
|
428
|
+
|
429
|
+
return false;
|
430
|
+
}
|
431
|
+
|
432
|
+
//--- private functions ----------------------------------------------------//
|
433
|
+
|
434
|
+
function _verifyService(IService service)
|
281
435
|
internal
|
282
|
-
|
436
|
+
view
|
283
437
|
returns(
|
284
|
-
IRegistry.ObjectInfo memory
|
438
|
+
IRegistry.ObjectInfo memory serviceInfo,
|
439
|
+
ObjectType serviceDomain,
|
440
|
+
VersionPart serviceVersion
|
285
441
|
)
|
286
442
|
{
|
287
|
-
|
443
|
+
if(!service.supportsInterface(type(IService).interfaceId)) {
|
444
|
+
revert ErrorReleaseManagerNotService(service);
|
445
|
+
}
|
288
446
|
|
289
|
-
|
290
|
-
|
447
|
+
address owner = msg.sender;
|
448
|
+
address serviceAuthority = service.authority();
|
449
|
+
serviceVersion = service.getVersion().toMajorPart();
|
450
|
+
serviceDomain = service.getDomain();// checked in registry
|
451
|
+
serviceInfo = service.getInitialInfo();
|
452
|
+
|
453
|
+
_verifyServiceInfo(service, serviceInfo, owner);
|
454
|
+
|
455
|
+
VersionPart releaseVersion = getNextVersion(); // never 0
|
456
|
+
address releaseAuthority = address(_releaseAccessManager[releaseVersion]); // can be zero if registering service when release is not created
|
457
|
+
|
458
|
+
// IMPORTANT: can not guarantee service access is actually controlled by authority
|
459
|
+
if(serviceAuthority != releaseAuthority) {
|
460
|
+
revert ErrorReleaseManagerServiceReleaseAuthorityMismatch(
|
461
|
+
service,
|
462
|
+
serviceAuthority,
|
463
|
+
releaseAuthority);
|
291
464
|
}
|
292
465
|
|
293
|
-
if(
|
294
|
-
revert
|
466
|
+
if(serviceVersion != releaseVersion) {
|
467
|
+
revert ErrorReleaseManagerServiceReleaseVersionMismatch(
|
468
|
+
service,
|
469
|
+
serviceVersion,
|
470
|
+
releaseVersion);
|
295
471
|
}
|
472
|
+
}
|
296
473
|
|
297
|
-
|
298
|
-
|
474
|
+
|
475
|
+
function _verifyServiceInfo(
|
476
|
+
IService service,
|
477
|
+
IRegistry.ObjectInfo memory info,
|
478
|
+
address expectedOwner // assume always valid, can not be 0
|
479
|
+
)
|
480
|
+
internal
|
481
|
+
view
|
482
|
+
{
|
483
|
+
if(info.objectAddress != address(service)) {
|
484
|
+
revert ErrorReleaseManagerServiceInfoAddressInvalid(service, address(service));
|
485
|
+
}
|
486
|
+
|
487
|
+
if(info.isInterceptor != false) { // service is never interceptor
|
488
|
+
revert ErrorReleaseManagerServiceInfoInterceptorInvalid(service, info.isInterceptor);
|
489
|
+
}
|
490
|
+
|
491
|
+
if(info.objectType != SERVICE()) {// type is checked in registry anyway...but service logic may depend on expected value
|
492
|
+
revert ErrorReleaseManagerServiceInfoTypeInvalid(service, SERVICE(), info.objectType);
|
299
493
|
}
|
300
494
|
|
301
495
|
address owner = info.initialOwner;
|
302
496
|
|
303
497
|
if(owner != expectedOwner) { // registerable owner protection
|
304
|
-
revert
|
498
|
+
revert ErrorReleaseManagerServiceInfoOwnerInvalid(service, expectedOwner, owner);
|
305
499
|
}
|
306
500
|
|
307
|
-
if(owner == address(
|
308
|
-
revert
|
501
|
+
if(owner == address(service)) {
|
502
|
+
revert ErrorReleaseManagerServiceSelfRegistration(service);
|
309
503
|
}
|
310
504
|
|
311
505
|
if(_registry.isRegistered(owner)) {
|
312
|
-
revert
|
506
|
+
revert ErrorReleaseManagerServiceOwnerRegistered(service, owner);
|
313
507
|
}
|
314
508
|
}
|
315
509
|
|
316
|
-
|
317
|
-
|
318
|
-
|
319
|
-
|
510
|
+
|
511
|
+
function _verifyReleaseAuthorizations(
|
512
|
+
address[] memory serviceAddress,
|
513
|
+
RoleId[][] memory serviceRoles,
|
514
|
+
RoleId[][] memory functionRoles,
|
515
|
+
bytes4[][][] memory selectors
|
320
516
|
)
|
321
517
|
internal
|
322
|
-
|
323
|
-
returns(ObjectType)
|
518
|
+
pure
|
324
519
|
{
|
325
|
-
|
326
|
-
|
327
|
-
if(majorVersion != expectedVersion) {
|
328
|
-
revert UnexpectedServiceVersion(expectedVersion, majorVersion);
|
520
|
+
if(serviceAddress.length == 0) {
|
521
|
+
revert ErrorReleaseManagerReleaseEmpty();
|
329
522
|
}
|
330
523
|
|
331
|
-
|
332
|
-
|
524
|
+
for(uint serviceIdx = 0; serviceIdx < serviceAddress.length; serviceIdx++)
|
525
|
+
{
|
526
|
+
for(uint roleIdx = 0; roleIdx < serviceRoles[serviceIdx].length; roleIdx++)
|
527
|
+
{
|
528
|
+
RoleId role = serviceRoles[serviceIdx][roleIdx];
|
529
|
+
if(role == ADMIN_ROLE() || role == PUBLIC_ROLE()) {
|
530
|
+
revert ErrorReleaseManagerReleaseServiceRoleInvalid(serviceIdx, serviceAddress[serviceIdx], role);
|
531
|
+
}
|
532
|
+
}
|
333
533
|
}
|
334
534
|
|
335
|
-
|
535
|
+
// TODO no duplicate service "domain" role per release
|
536
|
+
// TODO no duplicate service roles per service
|
537
|
+
// TODO no duplicate service function roles per service
|
538
|
+
// TODO no duplicate service function selectors per service
|
336
539
|
}
|
337
540
|
|
338
|
-
|
339
|
-
|
541
|
+
function _setServiceAuthorizations(
|
542
|
+
AccessManagerExtendedWithDisableInitializeable accessManager, // release access manager
|
543
|
+
address serviceAddress,
|
544
|
+
string memory serviceName,
|
545
|
+
RoleId[] memory serviceRoles,
|
546
|
+
string[] memory serviceRoleNames,
|
547
|
+
RoleId[] memory functionRoles,
|
548
|
+
string[] memory functionRoleNames,
|
549
|
+
bytes4[][] memory selectors
|
550
|
+
)
|
340
551
|
internal
|
341
552
|
{
|
342
|
-
|
553
|
+
accessManager.createTarget(serviceAddress, serviceName);
|
554
|
+
|
555
|
+
for(uint idx = 0; idx < functionRoles.length; idx++)
|
556
|
+
{
|
557
|
+
uint64 roleInt = functionRoles[idx].toInt();
|
558
|
+
|
559
|
+
if(!accessManager.isRoleExists(roleInt)) {
|
560
|
+
accessManager.createRole(roleInt, functionRoleNames[idx]);
|
561
|
+
}
|
343
562
|
|
344
|
-
|
345
|
-
|
563
|
+
accessManager.setTargetFunctionRole(
|
564
|
+
serviceAddress,
|
565
|
+
selectors[idx],
|
566
|
+
functionRoles[idx].toInt());
|
346
567
|
}
|
347
|
-
|
348
|
-
|
349
|
-
for(uint idx = 0; idx < config.length; idx++)
|
568
|
+
|
569
|
+
for(uint idx = 0; idx < serviceRoles.length; idx++)
|
350
570
|
{
|
351
|
-
|
352
|
-
|
353
|
-
if(
|
354
|
-
|
355
|
-
domain.eqz()
|
356
|
-
) { revert ConfigServiceDomainInvalid(idx, domain); }
|
357
|
-
|
358
|
-
bytes4[] memory selectors = config[idx].authorizedSelectors;
|
359
|
-
|
360
|
-
// TODO can be zero -> e.g. duplicate domain, first with zero selector, second with non zero selector -> need to check _release[version].domains.contains(domain) instead
|
361
|
-
// no overwrite
|
362
|
-
if(_selectors[version][domain].length > 0) {
|
363
|
-
revert SelectorAlreadyExists(version, domain);
|
571
|
+
uint64 roleInt = serviceRoles[idx].toInt();
|
572
|
+
|
573
|
+
if(!accessManager.isRoleExists(roleInt)) {
|
574
|
+
accessManager.createRole(roleInt, serviceRoleNames[idx]);
|
364
575
|
}
|
365
|
-
|
366
|
-
|
367
|
-
|
576
|
+
|
577
|
+
accessManager.grantRole(
|
578
|
+
serviceRoles[idx].toInt(),
|
579
|
+
serviceAddress,
|
580
|
+
0);
|
581
|
+
}
|
582
|
+
}
|
583
|
+
|
584
|
+
// returns true iff a the address passes some simple proxy tests.
|
585
|
+
function _isRegistry(address registryAddress) internal view returns (bool) {
|
586
|
+
|
587
|
+
// zero address is certainly not registry
|
588
|
+
if (registryAddress == address(0)) {
|
589
|
+
return false;
|
590
|
+
}
|
591
|
+
// TODO try catch and return false in case of revert
|
592
|
+
// a just panic
|
593
|
+
// check if contract returns a zero nft id for its own address
|
594
|
+
if (IRegistry(registryAddress).getNftId(registryAddress).eqz()) {
|
595
|
+
return false;
|
368
596
|
}
|
369
|
-
// TODO set when activated?
|
370
|
-
_release[version].createdAt = TimestampLib.blockTimestamp();
|
371
|
-
//_release[version].updatedAt = TimestampLib.blockTimestamp();
|
372
597
|
|
373
|
-
|
598
|
+
return true;
|
374
599
|
}
|
375
600
|
}
|