@etherisc/gif-next 0.0.2-836e6e4-400 → 0.0.2-83889c4-030
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 +10 -14
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +1416 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1349 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +818 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +975 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +814 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +73 -83
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +286 -1351
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +308 -199
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +463 -2526
- 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 +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +228 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +630 -351
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +510 -336
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +378 -88
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3642 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -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/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 +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 +30 -144
- 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/{ITreasury.sol/ITreasury.json → IComponents.sol/IComponents.json} +2 -2
- 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/{instance/module/ISetup.sol/ISetup.json → oracle/IOracle.sol/IOracle.json} +2 -2
- 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 +4 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1105 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +746 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +286 -265
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +1154 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1065 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.json +1565 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1432 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +738 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +834 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +722 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1278 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +810 -0
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IProductService.sol/IProductService.json → product/IApplicationService.sol/IApplicationService.json} +203 -240
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +759 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IPolicyService.sol/IPolicyService.json +326 -283
- 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} +263 -226
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +995 -0
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/{components/IBaseComponent.sol/IBaseComponent.json → product/IProductService.sol/IProductService.json} +125 -122
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1146 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +754 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +983 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +778 -0
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
- package/artifacts/contracts/product/Product.sol/Product.json +1397 -0
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +679 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +694 -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 +279 -17
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +355 -221
- 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 +512 -36
- 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 +507 -287
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +340 -82
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +845 -99
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +137 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +360 -96
- 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 +4 -0
- package/artifacts/contracts/shared/Component.sol/Component.json +896 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1490 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +792 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/base/ComponentServiceBase.sol/ComponentServiceBase.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +200 -195
- 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/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 +4 -0
- package/artifacts/contracts/{components/BaseComponent.sol/BaseComponent.json → shared/IComponent.sol/IComponent.json} +277 -115
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +867 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +705 -0
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/{instance/IInstanceBase.sol/IInstanceBase.json → shared/IKeyValueStore.sol/IKeyValueStore.json} +51 -31
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +34 -30
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +207 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +15 -35
- 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 +75 -163
- 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/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 +4 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +1036 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +571 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +194 -0
- 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 +115 -29
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +320 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +330 -62
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +132 -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 +179 -153
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +60 -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/IStaking.sol/IStaking.dbg.json +4 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1438 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +993 -0
- 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 +4 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.json +2045 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +777 -0
- 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 +4 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1324 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +726 -0
- 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 +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 +345 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +225 -0
- 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 +209 -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/type/ObjectType.sol/ObjectTypeLib.json +105 -0
- 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/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 +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 +198 -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/type/Timestamp.sol/TimestampLib.json +293 -0
- 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 +261 -0
- package/contracts/distribution/DistributionService.sol +298 -0
- package/contracts/distribution/DistributionServiceManager.sol +42 -0
- package/contracts/distribution/IDistributionComponent.sol +66 -0
- package/contracts/distribution/IDistributionService.sol +81 -0
- package/contracts/instance/BundleManager.sol +22 -25
- package/contracts/instance/IInstance.sol +65 -45
- package/contracts/instance/IInstanceService.sol +60 -17
- package/contracts/instance/Instance.sol +155 -195
- package/contracts/instance/InstanceAdmin.sol +331 -0
- package/contracts/instance/InstanceAuthorizationsLib.sol +377 -0
- package/contracts/instance/InstanceReader.sol +160 -85
- package/contracts/instance/InstanceService.sol +272 -210
- package/contracts/instance/InstanceServiceManager.sol +12 -22
- package/contracts/instance/InstanceStore.sol +281 -0
- package/contracts/instance/base/BalanceStore.sol +118 -0
- package/contracts/instance/{Cloneable.sol → base/Cloneable.sol} +8 -3
- package/contracts/instance/base/ObjectCounter.sol +21 -0
- package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +16 -35
- package/contracts/instance/module/IAccess.sol +20 -22
- package/contracts/instance/module/IBundle.sol +8 -8
- package/contracts/instance/module/IComponents.sol +52 -0
- package/contracts/instance/module/IDistribution.sol +7 -4
- package/contracts/instance/module/IPolicy.sol +56 -17
- package/contracts/instance/module/IRisk.sol +1 -1
- package/contracts/{test/Usdc.sol → mock/Dip.sol} +5 -5
- 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 +296 -0
- package/contracts/pool/BundleServiceManager.sol +42 -0
- package/contracts/pool/IBundleService.sol +106 -0
- package/contracts/pool/IPoolComponent.sol +112 -0
- package/contracts/pool/IPoolService.sol +150 -0
- package/contracts/pool/Pool.sol +299 -0
- package/contracts/pool/PoolService.sol +453 -0
- package/contracts/pool/PoolServiceManager.sol +42 -0
- package/contracts/product/ApplicationService.sol +254 -0
- package/contracts/product/ApplicationServiceManager.sol +38 -0
- package/contracts/product/ClaimService.sol +442 -0
- package/contracts/product/ClaimServiceManager.sol +38 -0
- package/contracts/product/IApplicationService.sol +62 -0
- package/contracts/product/IClaimService.sol +99 -0
- package/contracts/product/IPolicyService.sol +78 -0
- package/contracts/product/IPricingService.sol +39 -0
- package/contracts/product/IProductComponent.sol +42 -0
- package/contracts/product/IProductService.sol +33 -0
- package/contracts/product/PolicyService.sol +475 -0
- package/contracts/product/PolicyServiceManager.sol +42 -0
- package/contracts/product/PricingService.sol +301 -0
- package/contracts/product/PricingServiceManager.sol +42 -0
- package/contracts/product/Product.sol +377 -0
- package/contracts/product/ProductService.sol +124 -0
- package/contracts/product/ProductServiceManager.sol +42 -0
- package/contracts/registry/ChainNft.sol +16 -1
- package/contracts/registry/IRegistry.sol +56 -23
- package/contracts/registry/IRegistryService.sol +45 -34
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +300 -120
- package/contracts/registry/RegistryAdmin.sol +237 -0
- package/contracts/registry/RegistryService.sol +118 -175
- package/contracts/registry/RegistryServiceManager.sol +22 -26
- package/contracts/registry/ReleaseManager.sol +461 -209
- package/contracts/registry/ServiceAuthorizationsLib.sol +173 -0
- package/contracts/registry/TokenRegistry.sol +263 -58
- 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 +281 -0
- package/contracts/shared/ComponentService.sol +618 -0
- package/contracts/shared/ComponentServiceManager.sol +35 -0
- package/contracts/shared/ComponentVerifyingService.sol +117 -0
- package/contracts/shared/ERC165.sol +15 -13
- package/contracts/shared/IAccessManagerExtended.sol +74 -0
- package/contracts/shared/IAccessManagerExtendedWithDisable.sol +18 -0
- package/contracts/shared/IComponent.sol +70 -0
- package/contracts/shared/IComponentService.sol +102 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
- package/contracts/{instance/base → shared}/IKeyValueStore.sol +15 -11
- package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
- package/contracts/shared/INftOwnable.sol +13 -12
- package/contracts/shared/IPolicyHolder.sol +45 -0
- package/contracts/shared/IRegisterable.sol +4 -6
- package/contracts/shared/IRegistryLinked.sol +11 -0
- package/contracts/shared/IService.sol +7 -5
- package/contracts/shared/IVersionable.sol +5 -48
- package/contracts/shared/InitializableCustom.sol +177 -0
- package/contracts/shared/InstanceLinkedComponent.sol +144 -0
- package/contracts/shared/KeyValueStore.sol +127 -0
- package/contracts/{instance/base → shared}/Lifecycle.sol +37 -7
- package/contracts/shared/NftIdSetManager.sol +65 -0
- package/contracts/shared/NftOwnable.sol +59 -86
- package/contracts/shared/PolicyHolder.sol +102 -0
- package/contracts/shared/ProxyManager.sol +131 -26
- package/contracts/shared/Registerable.sol +26 -41
- package/contracts/shared/RegistryLinked.sol +43 -0
- package/contracts/shared/Service.sol +42 -23
- package/contracts/shared/TokenHandler.sol +37 -6
- package/contracts/shared/Versionable.sol +4 -92
- package/contracts/staking/IStaking.sol +168 -0
- package/contracts/staking/IStakingService.sol +149 -0
- package/contracts/staking/StakeManagerLib.sol +179 -0
- package/contracts/staking/Staking.sol +551 -0
- package/contracts/staking/StakingManager.sol +54 -0
- package/contracts/staking/StakingReader.sol +187 -0
- package/contracts/staking/StakingService.sol +406 -0
- package/contracts/staking/StakingServiceManager.sol +45 -0
- package/contracts/staking/StakingStore.sol +572 -0
- package/contracts/staking/TargetManagerLib.sol +207 -0
- package/contracts/{types → type}/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +128 -0
- package/contracts/{types → type}/Blocknumber.sol +21 -3
- package/contracts/type/ClaimId.sol +75 -0
- package/contracts/{types → type}/DistributorType.sol +2 -2
- package/contracts/{types → type}/Fee.sol +33 -23
- package/contracts/{types → type}/NftId.sol +21 -15
- package/contracts/{types → type}/NftIdSet.sol +2 -2
- package/contracts/{types → type}/ObjectType.sol +32 -16
- package/contracts/type/PayoutId.sol +82 -0
- package/contracts/{types → type}/Referral.sol +5 -1
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/{types → type}/RiskId.sol +1 -1
- package/contracts/type/RoleId.sol +146 -0
- package/contracts/type/Seconds.sol +81 -0
- package/contracts/{types → type}/StateId.sol +34 -4
- package/contracts/{types → type}/Timestamp.sol +23 -14
- package/contracts/{types → type}/UFixed.sol +1 -0
- package/contracts/{types → type}/Version.sol +2 -1
- package/package.json +6 -5
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +0 -772
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -152
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +0 -275
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -157
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
- package/artifacts/contracts/components/Pool.sol/Pool.json +0 -967
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
- package/artifacts/contracts/components/Product.sol/Product.json +0 -883
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +0 -50
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
- package/artifacts/contracts/instance/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1057
- package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.json +0 -763
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -285
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +0 -429
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -502
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -169
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -923
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -432
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -814
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -671
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -420
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.json +0 -466
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +0 -446
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -971
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -464
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -705
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -420
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -755
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -420
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -285
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +0 -4
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.json +0 -442
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -305
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
- package/artifacts/contracts/test/TestService.sol/TestService.json +0 -600
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -286
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
- package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
- 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/ObjectType.sol/ObjectTypeLib.json +0 -92
- 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/Timestamp.sol/TimestampLib.json +0 -249
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
- package/contracts/components/BaseComponent.sol +0 -148
- package/contracts/components/Distribution.sol +0 -163
- package/contracts/components/IBaseComponent.sol +0 -32
- package/contracts/components/IDistributionComponent.sol +0 -44
- package/contracts/components/IPoolComponent.sol +0 -66
- package/contracts/components/IProductComponent.sol +0 -35
- package/contracts/components/Pool.sol +0 -271
- package/contracts/components/Product.sol +0 -292
- package/contracts/experiment/cloning/Cloner.sol +0 -47
- package/contracts/experiment/errors/Require.sol +0 -38
- package/contracts/experiment/errors/Revert.sol +0 -44
- package/contracts/experiment/inheritance/A.sol +0 -53
- package/contracts/experiment/inheritance/B.sol +0 -28
- package/contracts/experiment/inheritance/C.sol +0 -34
- package/contracts/experiment/inheritance/IA.sol +0 -13
- package/contracts/experiment/inheritance/IB.sol +0 -10
- package/contracts/experiment/inheritance/IC.sol +0 -12
- package/contracts/experiment/statemachine/Dummy.sol +0 -27
- package/contracts/experiment/statemachine/ISM.sol +0 -25
- package/contracts/experiment/statemachine/SM.sol +0 -57
- package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
- package/contracts/experiment/types/TypeA.sol +0 -47
- package/contracts/experiment/types/TypeB.sol +0 -29
- package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +0 -23
- package/contracts/instance/IInstanceBase.sol +0 -26
- package/contracts/instance/InstanceAccessManager.sol +0 -304
- package/contracts/instance/InstanceBase.sol +0 -41
- package/contracts/instance/base/ComponentServiceBase.sol +0 -72
- package/contracts/instance/base/IInstanceBase.sol +0 -23
- package/contracts/instance/base/KeyValueStore.sol +0 -172
- package/contracts/instance/module/ISetup.sol +0 -46
- package/contracts/instance/module/ITreasury.sol +0 -23
- package/contracts/instance/service/BundleService.sol +0 -260
- package/contracts/instance/service/BundleServiceManager.sol +0 -51
- package/contracts/instance/service/ComponentOwnerService.sol +0 -315
- package/contracts/instance/service/DistributionService.sol +0 -114
- package/contracts/instance/service/DistributionServiceManager.sol +0 -51
- package/contracts/instance/service/IBundleService.sol +0 -45
- package/contracts/instance/service/IComponentOwnerService.sol +0 -20
- package/contracts/instance/service/IDistributionService.sol +0 -12
- package/contracts/instance/service/IPolicyService.sol +0 -87
- package/contracts/instance/service/IPoolService.sol +0 -20
- package/contracts/instance/service/IProductService.sol +0 -40
- package/contracts/instance/service/PolicyService.sol +0 -503
- package/contracts/instance/service/PolicyServiceManager.sol +0 -54
- package/contracts/instance/service/PoolService.sol +0 -122
- package/contracts/instance/service/PoolServiceManager.sol +0 -51
- package/contracts/instance/service/ProductService.sol +0 -168
- package/contracts/instance/service/ProductServiceManager.sol +0 -54
- package/contracts/registry/RegistryAccessManager.sol +0 -210
- package/contracts/shared/ContractDeployerLib.sol +0 -72
- package/contracts/shared/RegisterableUpgradable.sol +0 -16
- package/contracts/test/TestFee.sol +0 -25
- package/contracts/test/TestRegisterable.sol +0 -18
- package/contracts/test/TestRoleId.sol +0 -14
- package/contracts/test/TestService.sol +0 -25
- package/contracts/test/TestToken.sol +0 -26
- package/contracts/test/TestVersion.sol +0 -44
- package/contracts/test/TestVersionable.sol +0 -17
- 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}/Key32.sol +0 -0
@@ -1,223 +1,371 @@
|
|
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
|
-
import {NftId} from "../
|
7
|
-
import {RoleId} from "../
|
8
|
-
import {ObjectType, ObjectTypeLib,
|
9
|
-
import {VersionPart, VersionPartLib} from "../
|
10
|
-
import {Timestamp, TimestampLib} from "../
|
11
|
+
import {NftId} from "../type/NftId.sol";
|
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";
|
18
|
+
import {Version, VersionLib, VersionPart, VersionPartLib} from "../type/Version.sol";
|
11
19
|
|
12
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";
|
24
|
+
import {IRegisterable} from "../shared/IRegisterable.sol";
|
13
25
|
|
14
26
|
import {IRegistry} from "./IRegistry.sol";
|
15
|
-
import {
|
27
|
+
import {IRegistryLinked} from "../shared/IRegistryLinked.sol";
|
16
28
|
import {IRegistryService} from "./IRegistryService.sol";
|
17
|
-
import {
|
29
|
+
import {RegistryAdmin} from "./RegistryAdmin.sol";
|
30
|
+
import {Registry} from "./Registry.sol";
|
31
|
+
import {TokenRegistry} from "./TokenRegistry.sol";
|
32
|
+
import {ServiceAuthorizationsLib} from "./ServiceAuthorizationsLib.sol";
|
18
33
|
|
19
34
|
|
20
|
-
contract ReleaseManager is
|
35
|
+
contract ReleaseManager is
|
36
|
+
AccessManaged,
|
37
|
+
ILifecycle,
|
38
|
+
IRegistryLinked
|
21
39
|
{
|
22
40
|
using ObjectTypeLib for ObjectType;
|
23
41
|
|
24
|
-
|
25
|
-
event LogReleaseActivation(VersionPart version);
|
26
|
-
|
27
|
-
// createNextRelease
|
28
|
-
error NotRegistryService();
|
29
|
-
error UnexpectedServiceAuthority(address expected, address found);
|
42
|
+
uint256 public constant INITIAL_GIF_VERSION = 3;
|
30
43
|
|
31
|
-
|
32
|
-
|
33
|
-
error ServiceNotInRelease(IService service, ObjectType serviceDomain);
|
44
|
+
event LogReleaseCreation(VersionPart version, bytes32 salt, AccessManagerExtendedWithDisableInitializeable accessManager);
|
45
|
+
event LogReleaseActivation(VersionPart version);
|
34
46
|
|
35
|
-
//
|
36
|
-
|
37
|
-
//error ReleaseRegistrationNotFinished();
|
47
|
+
// constructor
|
48
|
+
error ErrorReleaseManagerNotRegistry(Registry registry);
|
38
49
|
|
39
|
-
//
|
40
|
-
error
|
41
|
-
error NotRegisterableOwner(address notOwner);
|
42
|
-
error SelfRegistration();
|
43
|
-
error RegisterableOwnerIsRegistered();
|
50
|
+
// createNextRelease
|
51
|
+
error ErrorReleaseManagerReleaseCreationDisallowed(StateId currentStateId);
|
44
52
|
|
45
|
-
//
|
46
|
-
error
|
47
|
-
error
|
53
|
+
// prepareRelease
|
54
|
+
error ErrorReleaseManagerReleasePreparationDisallowed(StateId currentStateId);
|
55
|
+
error ErrorReleaseManagerReleaseAlreadyPrepared(VersionPart version);
|
48
56
|
|
49
|
-
//
|
50
|
-
error
|
51
|
-
error ConfigServiceDomainInvalid(uint configArrayIndex, ObjectType domain);
|
52
|
-
error ConfigSelectorZero(uint configArrayIndex);
|
53
|
-
error SelectorAlreadyExists(VersionPart releaseVersion, ObjectType serviceDomain);
|
57
|
+
// register staking
|
58
|
+
//error ErrorReleaseManagerStakingAlreadySet(address stakingAddress);
|
54
59
|
|
60
|
+
// registerService
|
61
|
+
error ErrorReleaseManagerNoServiceRegistrationExpected();
|
62
|
+
error ErrorReleaseManagerServiceRegistrationDisallowed(StateId currentStateId);
|
63
|
+
error ErrorReleaseManagerNotService(IService service);
|
64
|
+
error ErrorReleaseManagerServiceAddressInvalid(IService given, address expected);
|
55
65
|
|
56
|
-
|
57
|
-
|
66
|
+
// activateNextRelease
|
67
|
+
error ErrorReleaseManagerReleaseActivationDisallowed(StateId currentStateId);
|
68
|
+
error ErrorReleaseManagerReleaseNotCreated(VersionPart releaseVersion);
|
69
|
+
error ErrorReleaseManagerReleaseRegistrationNotFinished(VersionPart releaseVersion, uint awaitingRegistration);
|
70
|
+
error ErrorReleaseManagerReleaseAlreadyActivated(VersionPart releaseVersion);
|
58
71
|
|
59
|
-
|
60
|
-
VersionPart
|
72
|
+
// disableRelease
|
73
|
+
error ErrorReleaseManagerReleaseNotActivated(VersionPart releaseVersion);
|
74
|
+
error ErrorReleaseManagerReleaseAlreadyDisabled(VersionPart releaseVersion);
|
61
75
|
|
62
|
-
|
76
|
+
// _verifyService
|
77
|
+
error ErrorReleaseManagerServiceReleaseAuthorityMismatch(IService service, address serviceAuthority, address releaseAuthority);
|
78
|
+
error ErrorReleaseManagerServiceReleaseVersionMismatch(IService service, VersionPart serviceVersion, VersionPart releaseVersion);
|
63
79
|
|
64
|
-
|
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
|
+
}
|
65
119
|
|
66
|
-
|
120
|
+
_registry = registry;
|
121
|
+
setAuthority(_registry.getAuthority());
|
122
|
+
_admin = RegistryAdmin(_registry.getRegistryAdminAddress());
|
67
123
|
|
68
|
-
|
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
|
+
}
|
69
133
|
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
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)
|
74
140
|
{
|
75
|
-
|
76
|
-
|
77
|
-
|
141
|
+
if (!isValidTransition(RELEASE(), _state, SCHEDULED())) {
|
142
|
+
revert ErrorReleaseManagerReleaseCreationDisallowed(_state);
|
143
|
+
}
|
78
144
|
|
79
|
-
|
145
|
+
_next = VersionPartLib.toVersionPart(_next.toInt() + 1);
|
146
|
+
_awaitingRegistration = 0;
|
147
|
+
_state = SCHEDULED();
|
80
148
|
|
81
|
-
|
149
|
+
return _next;
|
82
150
|
}
|
83
151
|
|
84
|
-
// TODO
|
85
|
-
|
86
|
-
|
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
|
162
|
+
)
|
87
163
|
external
|
88
|
-
restricted //
|
89
|
-
returns(
|
164
|
+
restricted() // GIF_MANAGER_ROLE
|
165
|
+
returns(
|
166
|
+
address releaseAccessManagerAddress,
|
167
|
+
VersionPart version,
|
168
|
+
bytes32 releaseSalt
|
169
|
+
)
|
90
170
|
{
|
91
|
-
|
92
|
-
revert NotRegistryService();
|
93
|
-
}
|
94
|
-
// TODO unreliable! MUST guarantee the same authority -> how?
|
95
|
-
if(service.authority() != authority()) {
|
96
|
-
revert UnexpectedServiceAuthority(
|
97
|
-
authority(),
|
98
|
-
service.authority());
|
99
|
-
}
|
100
|
-
|
101
|
-
(
|
102
|
-
IRegistry.ObjectInfo memory info,
|
103
|
-
bytes memory data
|
104
|
-
) = _getAndVerifyContractInfo(service, SERVICE(), msg.sender);
|
171
|
+
version = getNextVersion();
|
105
172
|
|
106
|
-
|
107
|
-
|
108
|
-
|
173
|
+
// ensures unique salt
|
174
|
+
releaseSalt = keccak256(
|
175
|
+
bytes.concat(
|
176
|
+
bytes32(version.toInt()),
|
177
|
+
salt));
|
109
178
|
|
110
|
-
|
179
|
+
releaseAccessManagerAddress = Clones.cloneDeterministic(_releaseAccessManagerCodeAddress, releaseSalt);
|
180
|
+
AccessManagerExtendedWithDisableInitializeable releaseAccessManager = AccessManagerExtendedWithDisableInitializeable(releaseAccessManagerAddress);
|
181
|
+
releaseAccessManager.initialize(address(this), version);
|
111
182
|
|
112
|
-
|
113
|
-
|
114
|
-
|
183
|
+
if (!isValidTransition(RELEASE(), _state, DEPLOYING())) {
|
184
|
+
revert ErrorReleaseManagerReleasePreparationDisallowed(_state);
|
185
|
+
}
|
115
186
|
|
116
|
-
|
117
|
-
service.linkToRegisteredNftId();
|
187
|
+
_verifyReleaseAuthorizations(addresses, serviceRoles, functionRoles, selectors);
|
118
188
|
|
119
|
-
|
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);
|
120
207
|
}
|
121
208
|
|
122
|
-
|
123
|
-
// TODO removing service from release? -> set _active to false forever, but keep all other records?
|
209
|
+
|
124
210
|
function registerService(IService service)
|
125
211
|
external
|
126
212
|
restricted // GIF_MANAGER_ROLE
|
127
213
|
returns(NftId nftId)
|
128
214
|
{
|
129
|
-
if(!
|
130
|
-
revert
|
215
|
+
if (!isValidTransition(RELEASE(), _state, DEPLOYING())) {
|
216
|
+
revert ErrorReleaseManagerServiceRegistrationDisallowed(_state);
|
131
217
|
}
|
132
218
|
|
133
219
|
(
|
134
|
-
IRegistry.ObjectInfo memory info,
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
VersionPart version = getNextVersion();
|
139
|
-
ObjectType domain = _verifyServiceInfo(info, version, zeroObjectType());
|
140
|
-
|
141
|
-
bytes4[] memory selector = new bytes4[](1);
|
142
|
-
selector[0] = _selector[version][domain];
|
220
|
+
IRegistry.ObjectInfo memory info,
|
221
|
+
ObjectType domain,
|
222
|
+
VersionPart version
|
223
|
+
) = _verifyService(service);
|
143
224
|
|
144
|
-
//
|
145
|
-
if(
|
146
|
-
revert
|
225
|
+
// redundant with state var
|
226
|
+
if (_awaitingRegistration == 0) {
|
227
|
+
revert ErrorReleaseManagerNoServiceRegistrationExpected();
|
147
228
|
}
|
148
229
|
|
149
|
-
|
150
|
-
address
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
_awaitingRegistration--;
|
157
|
-
|
158
|
-
// activate release
|
159
|
-
if(_awaitingRegistration == 0) {
|
160
|
-
_latest = version;
|
161
|
-
_active[registryService] = true;
|
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
|
+
}*/
|
162
236
|
|
163
|
-
|
164
|
-
|
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);
|
165
264
|
|
166
265
|
nftId = _registry.registerService(info, version, domain);
|
167
266
|
|
168
|
-
|
169
|
-
service.linkToRegisteredNftId();
|
267
|
+
service.linkToRegisteredNftId();
|
170
268
|
}
|
171
269
|
|
172
|
-
|
270
|
+
|
271
|
+
function activateNextRelease()
|
173
272
|
external
|
174
273
|
restricted // GIF_ADMIN_ROLE
|
175
274
|
{
|
176
|
-
|
275
|
+
if (!isValidTransition(RELEASE(), _state, ACTIVE())) {
|
276
|
+
revert ErrorReleaseManagerReleaseActivationDisallowed(_state);
|
277
|
+
}
|
278
|
+
|
279
|
+
VersionPart version = _next;
|
177
280
|
address service = _registry.getServiceAddress(REGISTRY(), version);
|
178
281
|
|
179
|
-
// release
|
282
|
+
// release exists, registry service is a MUST
|
283
|
+
//if(_releaseAccessManager[version] == address(0)) {
|
180
284
|
if(service == address(0)) {
|
181
|
-
revert
|
285
|
+
revert ErrorReleaseManagerReleaseNotCreated(version);
|
182
286
|
}
|
183
287
|
|
184
288
|
// release fully deployed
|
185
289
|
if(_awaitingRegistration > 0) {
|
186
|
-
revert
|
290
|
+
revert ErrorReleaseManagerReleaseRegistrationNotFinished(version, _awaitingRegistration);
|
187
291
|
}
|
188
292
|
|
189
|
-
//
|
293
|
+
// release is not activated
|
294
|
+
if(_releaseInfo[version].activatedAt.gtz()) {
|
295
|
+
revert ErrorReleaseManagerReleaseAlreadyActivated(version);
|
296
|
+
}
|
190
297
|
|
191
298
|
_latest = version;
|
192
|
-
|
299
|
+
_state = ACTIVE();
|
193
300
|
|
194
|
-
|
195
|
-
|
301
|
+
_releaseVersionByAddress[service] = version;
|
302
|
+
_releaseInfo[version].activatedAt = TimestampLib.blockTimestamp();
|
196
303
|
|
197
|
-
|
304
|
+
emit LogReleaseActivation(version);
|
305
|
+
}
|
198
306
|
|
199
|
-
|
307
|
+
// release becomes disabled after delay expiration (can be reenabled before that)
|
308
|
+
function disableRelease(VersionPart version, Seconds disableDelay)
|
309
|
+
external
|
310
|
+
restricted // GIF_ADMIN_ROLE
|
200
311
|
{
|
201
|
-
|
202
|
-
|
312
|
+
// release was activated
|
313
|
+
if(_releaseInfo[version].activatedAt.eqz()) {
|
314
|
+
revert ErrorReleaseManagerReleaseNotActivated(version);
|
315
|
+
}
|
203
316
|
|
204
|
-
|
317
|
+
// release not disabled already
|
318
|
+
if(_releaseInfo[version].disabledAt.gtz()) {
|
319
|
+
revert ErrorReleaseManagerReleaseAlreadyDisabled(version);
|
320
|
+
}
|
321
|
+
|
322
|
+
disableDelay = SecondsLib.toSeconds(Math.max(disableDelay.toInt(), MIN_DISABLE_DELAY.toInt()));
|
323
|
+
|
324
|
+
_releaseAccessManager[version].disable(disableDelay);
|
325
|
+
|
326
|
+
_releaseInfo[version].disabledAt = TimestampLib.blockTimestamp().addSeconds(disableDelay);
|
327
|
+
}
|
328
|
+
|
329
|
+
function enableRelease(VersionPart version)
|
330
|
+
external
|
331
|
+
restricted // GIF_ADMIN_ROLE
|
205
332
|
{
|
206
|
-
|
333
|
+
// release was disabled
|
334
|
+
//if(_releaseInfo[version].disabledAt.eqz()) {
|
335
|
+
// revert ErrorReleaseManagerReleaseAlreadyEnabled(version);
|
336
|
+
//}
|
337
|
+
|
338
|
+
// reverts if disable delay expired
|
339
|
+
_releaseAccessManager[version].enable();
|
340
|
+
|
341
|
+
_releaseInfo[version].disabledAt = zeroTimestamp();
|
207
342
|
}
|
208
343
|
|
209
|
-
|
210
|
-
|
211
|
-
|
344
|
+
//--- view functions ----------------------------------------------------//
|
345
|
+
|
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);
|
212
352
|
}
|
213
353
|
|
214
|
-
function
|
215
|
-
|
216
|
-
|
354
|
+
function isActiveRegistryService(address service) external view returns(bool) {
|
355
|
+
VersionPart version = _releaseVersionByAddress[service];
|
356
|
+
return isActiveRelease(version);
|
357
|
+
}
|
358
|
+
|
359
|
+
function isActiveRelease(VersionPart version) public view returns(bool) {
|
360
|
+
return _releaseInfo[version].activatedAt.gtz();
|
361
|
+
}
|
217
362
|
|
218
|
-
|
219
|
-
|
220
|
-
|
363
|
+
function getReleaseInfo(VersionPart version) external view returns(IRegistry.ReleaseInfo memory) {
|
364
|
+
return _releaseInfo[version];
|
365
|
+
}
|
366
|
+
|
367
|
+
function getNextVersion() public view returns(VersionPart) {
|
368
|
+
return _next;
|
221
369
|
}
|
222
370
|
|
223
371
|
function getLatestVersion() external view returns(VersionPart) {
|
@@ -228,121 +376,225 @@ contract ReleaseManager is AccessManaged
|
|
228
376
|
return _initial;
|
229
377
|
}
|
230
378
|
|
379
|
+
function getState() external view returns (StateId stateId) {
|
380
|
+
return _state;
|
381
|
+
}
|
382
|
+
|
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
|
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
|
+
|
231
432
|
//--- private functions ----------------------------------------------------//
|
232
433
|
|
233
|
-
function
|
434
|
+
function _verifyService(IService service)
|
435
|
+
internal
|
436
|
+
view
|
437
|
+
returns(
|
438
|
+
IRegistry.ObjectInfo memory serviceInfo,
|
439
|
+
ObjectType serviceDomain,
|
440
|
+
VersionPart serviceVersion
|
441
|
+
)
|
442
|
+
{
|
443
|
+
if(!service.supportsInterface(type(IService).interfaceId)) {
|
444
|
+
revert ErrorReleaseManagerNotService(service);
|
445
|
+
}
|
446
|
+
|
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);
|
464
|
+
}
|
465
|
+
|
466
|
+
if(serviceVersion != releaseVersion) {
|
467
|
+
revert ErrorReleaseManagerServiceReleaseVersionMismatch(
|
468
|
+
service,
|
469
|
+
serviceVersion,
|
470
|
+
releaseVersion);
|
471
|
+
}
|
472
|
+
}
|
473
|
+
|
474
|
+
|
475
|
+
function _verifyServiceInfo(
|
234
476
|
IService service,
|
235
|
-
|
477
|
+
IRegistry.ObjectInfo memory info,
|
236
478
|
address expectedOwner // assume always valid, can not be 0
|
237
479
|
)
|
238
480
|
internal
|
239
481
|
view
|
240
|
-
returns(
|
241
|
-
IRegistry.ObjectInfo memory info,
|
242
|
-
bytes memory data
|
243
|
-
)
|
244
482
|
{
|
245
|
-
(info
|
246
|
-
|
247
|
-
|
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
|
+
}
|
248
490
|
|
249
|
-
if(info.objectType !=
|
250
|
-
revert
|
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);
|
251
493
|
}
|
252
494
|
|
253
495
|
address owner = info.initialOwner;
|
254
496
|
|
255
497
|
if(owner != expectedOwner) { // registerable owner protection
|
256
|
-
revert
|
498
|
+
revert ErrorReleaseManagerServiceInfoOwnerInvalid(service, expectedOwner, owner);
|
257
499
|
}
|
258
500
|
|
259
501
|
if(owner == address(service)) {
|
260
|
-
revert
|
502
|
+
revert ErrorReleaseManagerServiceSelfRegistration(service);
|
261
503
|
}
|
262
|
-
|
263
|
-
/*if(owner == address(0)) { // never 0
|
264
|
-
revert();// RegisterableOwnerIsZero();
|
265
|
-
}*/
|
266
504
|
|
267
505
|
if(_registry.isRegistered(owner)) {
|
268
|
-
revert
|
506
|
+
revert ErrorReleaseManagerServiceOwnerRegistered(service, owner);
|
269
507
|
}
|
270
|
-
|
271
|
-
/*NftId parentNftId = info.parentNftId;
|
272
|
-
IRegistry.ObjectInfo memory parentInfo = getRegistry().getObjectInfo(parentNftId);
|
273
|
-
|
274
|
-
if(parentInfo.objectType != parentType) { // parent registration + type
|
275
|
-
revert InvalidParent(parentNftId);
|
276
|
-
}*/
|
277
|
-
|
278
|
-
return(info, data);
|
279
508
|
}
|
280
509
|
|
281
|
-
|
282
|
-
|
283
|
-
|
284
|
-
|
510
|
+
|
511
|
+
function _verifyReleaseAuthorizations(
|
512
|
+
address[] memory serviceAddress,
|
513
|
+
RoleId[][] memory serviceRoles,
|
514
|
+
RoleId[][] memory functionRoles,
|
515
|
+
bytes4[][][] memory selectors
|
285
516
|
)
|
286
517
|
internal
|
287
|
-
|
288
|
-
returns(ObjectType)
|
518
|
+
pure
|
289
519
|
{
|
290
|
-
(
|
291
|
-
|
292
|
-
VersionPart version
|
293
|
-
) = abi.decode(info.data, (ObjectType, VersionPart));
|
294
|
-
|
295
|
-
if(version != expectedVersion) {
|
296
|
-
revert UnexpectedServiceVersion(expectedVersion, version);
|
520
|
+
if(serviceAddress.length == 0) {
|
521
|
+
revert ErrorReleaseManagerReleaseEmpty();
|
297
522
|
}
|
298
523
|
|
299
|
-
|
300
|
-
|
301
|
-
|
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
|
+
}
|
302
532
|
}
|
303
533
|
}
|
304
534
|
|
305
|
-
|
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
|
306
539
|
}
|
307
540
|
|
308
|
-
|
309
|
-
|
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
|
+
)
|
310
551
|
internal
|
311
552
|
{
|
312
|
-
|
313
|
-
IRegistryService.FunctionConfig[] memory config = abi.decode(configBytes, (IRegistryService.FunctionConfig[]));
|
553
|
+
accessManager.createTarget(serviceAddress, serviceName);
|
314
554
|
|
315
|
-
|
316
|
-
revert ConfigMissing();
|
317
|
-
}
|
318
|
-
// always in release
|
319
|
-
_release[version].domains.push(REGISTRY());
|
320
|
-
for(uint idx = 0; idx < config.length; idx++)
|
555
|
+
for(uint idx = 0; idx < functionRoles.length; idx++)
|
321
556
|
{
|
322
|
-
|
323
|
-
bytes4 selector = config[idx].selector;
|
557
|
+
uint64 roleInt = functionRoles[idx].toInt();
|
324
558
|
|
325
|
-
|
326
|
-
|
327
|
-
|
328
|
-
domain.eqz()
|
329
|
-
) { revert ConfigServiceDomainInvalid(idx, domain); }
|
559
|
+
if(!accessManager.isRoleExists(roleInt)) {
|
560
|
+
accessManager.createRole(roleInt, functionRoleNames[idx]);
|
561
|
+
}
|
330
562
|
|
331
|
-
|
332
|
-
|
563
|
+
accessManager.setTargetFunctionRole(
|
564
|
+
serviceAddress,
|
565
|
+
selectors[idx],
|
566
|
+
functionRoles[idx].toInt());
|
567
|
+
}
|
568
|
+
|
569
|
+
for(uint idx = 0; idx < serviceRoles.length; idx++)
|
570
|
+
{
|
571
|
+
uint64 roleInt = serviceRoles[idx].toInt();
|
333
572
|
|
334
|
-
|
335
|
-
|
336
|
-
revert SelectorAlreadyExists(version, domain);
|
573
|
+
if(!accessManager.isRoleExists(roleInt)) {
|
574
|
+
accessManager.createRole(roleInt, serviceRoleNames[idx]);
|
337
575
|
}
|
338
|
-
|
339
|
-
|
340
|
-
|
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;
|
341
596
|
}
|
342
|
-
// TODO set when activated?
|
343
|
-
_release[version].createdAt = TimestampLib.blockTimestamp();
|
344
|
-
//_release[version].updatedAt = TimestampLib.blockTimestamp();
|
345
597
|
|
346
|
-
|
598
|
+
return true;
|
347
599
|
}
|
348
600
|
}
|