@etherisc/gif-next 0.0.2-c00cf5d-513 → 0.0.2-c0457ac-280
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/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +198 -177
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +130 -335
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +67 -96
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +83 -108
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +35 -48
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +32 -101
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +65 -66
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +163 -10
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +81 -93
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +56 -40
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +84 -44
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +458 -331
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +268 -46
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +74 -43
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +1095 -344
- 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 +1 -1
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +0 -53
- 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 -71
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- 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/{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 +675 -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 +1034 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +730 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +91 -264
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +56 -69
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +19 -51
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +145 -86
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +134 -133
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +242 -103
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +180 -376
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +42 -83
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +93 -167
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +56 -45
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +121 -211
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +64 -61
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +20 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +20 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +94 -25
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +40 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +241 -107
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/product/IProductService.sol/IProductService.json +13 -55
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +180 -297
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +54 -99
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +163 -174
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +81 -54
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +337 -157
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +47 -230
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +34 -47
- 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 +65 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +153 -1
- package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.json +129 -0
- 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 +294 -15
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1712 -103
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +198 -28
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +45 -42
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +321 -161
- package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.json +171 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +187 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +314 -136
- package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.json +1559 -0
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +42 -10
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +42 -10
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +52 -20
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +52 -20
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +100 -96
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +916 -55
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +796 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +539 -0
- 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/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.json +1189 -0
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +1 -1
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +76 -81
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +880 -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/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +1 -11
- 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 +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 +20 -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 +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 +33 -20
- 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 +19 -32
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +17 -22
- 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 +16 -16
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +40 -4
- 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 +4 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1438 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +566 -54
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +460 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.json +2005 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +761 -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 +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +657 -100
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +65 -46
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2261 -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 +53 -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 +34 -34
- 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 +47 -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 +96 -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 +4 -4
- 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 +114 -4
- 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/Selector.sol/SelectorLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
- 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/String.sol/StrLib.dbg.json +4 -0
- package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
- 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 +29 -53
- package/contracts/distribution/DistributionService.sol +61 -115
- package/contracts/distribution/IDistributionComponent.sol +5 -10
- package/contracts/distribution/IDistributionService.sol +2 -8
- package/contracts/instance/IInstance.sol +15 -7
- package/contracts/instance/IInstanceService.sol +35 -10
- package/contracts/instance/Instance.sol +63 -34
- package/contracts/instance/InstanceAdmin.sol +3 -2
- package/contracts/instance/InstanceAuthorizationsLib.sol +84 -27
- package/contracts/instance/InstanceReader.sol +64 -40
- package/contracts/instance/InstanceService.sol +185 -45
- package/contracts/instance/InstanceStore.sol +122 -64
- package/contracts/instance/base/BalanceStore.sol +123 -0
- package/contracts/instance/base/Cloneable.sol +2 -25
- package/contracts/instance/base/ObjectCounter.sol +21 -0
- package/contracts/instance/base/ObjectManager.sol +1 -3
- package/contracts/instance/module/IBundle.sol +1 -4
- package/contracts/instance/module/IComponents.sol +15 -4
- package/contracts/instance/module/IPolicy.sol +8 -2
- 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 +278 -0
- package/contracts/oracle/OracleServiceManager.sol +42 -0
- package/contracts/pool/BundleService.sol +79 -167
- package/contracts/pool/IBundleService.sol +4 -16
- package/contracts/pool/IPoolComponent.sol +4 -6
- package/contracts/pool/IPoolService.sol +45 -9
- package/contracts/pool/Pool.sol +39 -42
- package/contracts/pool/PoolService.sol +190 -142
- package/contracts/product/ApplicationService.sol +109 -42
- package/contracts/product/ClaimService.sol +18 -19
- package/contracts/product/IApplicationService.sol +1 -1
- package/contracts/product/IClaimService.sol +7 -1
- package/contracts/product/IPolicyService.sol +6 -8
- package/contracts/product/IPricingService.sol +3 -1
- package/contracts/product/IProductComponent.sol +7 -6
- package/contracts/product/IProductService.sol +1 -8
- package/contracts/product/PolicyService.sol +225 -128
- package/contracts/product/PricingService.sol +72 -48
- package/contracts/product/Product.sol +47 -49
- package/contracts/product/ProductService.sol +26 -114
- package/contracts/registry/ChainNft.sol +8 -1
- package/contracts/registry/IRegistry.sol +15 -4
- package/contracts/registry/IRegistryService.sol +10 -0
- package/contracts/registry/IServiceAuthorization.sol +35 -0
- package/contracts/registry/Registry.sol +164 -47
- package/contracts/registry/RegistryAdmin.sol +264 -72
- package/contracts/registry/RegistryService.sol +48 -14
- package/contracts/registry/RegistryServiceManager.sol +2 -9
- package/contracts/registry/ReleaseManager.sol +242 -177
- package/contracts/registry/ServiceAuthorization.sol +86 -0
- package/contracts/registry/ServiceAuthorizationV3.sol +200 -0
- package/contracts/registry/TokenRegistry.sol +261 -64
- package/contracts/shared/AccessAdmin.sol +759 -0
- package/contracts/shared/AccessManagerCustom.sol +6 -1
- package/contracts/shared/AccessManagerExtended.sol +19 -7
- package/contracts/shared/Component.sol +139 -129
- package/contracts/shared/ComponentService.sol +563 -88
- package/contracts/shared/ComponentServiceManager.sol +35 -0
- package/contracts/shared/ComponentVerifyingService.sol +117 -0
- package/contracts/shared/ERC165.sol +1 -1
- package/contracts/shared/IAccessAdmin.sol +168 -0
- package/contracts/shared/IComponent.sol +17 -37
- package/contracts/shared/IComponentService.sol +102 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
- package/contracts/{instance/base → shared}/IKeyValueStore.sol +6 -6
- package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
- package/contracts/shared/INftOwnable.sol +1 -1
- package/contracts/shared/IPolicyHolder.sol +6 -1
- package/contracts/shared/IService.sol +8 -1
- package/contracts/shared/InitializableCustom.sol +177 -0
- package/contracts/shared/InstanceLinkedComponent.sol +144 -0
- package/contracts/{instance/base → shared}/KeyValueStore.sol +30 -72
- package/contracts/{instance/base → shared}/Lifecycle.sol +12 -3
- package/contracts/shared/NftIdSetManager.sol +65 -0
- package/contracts/shared/NftOwnable.sol +3 -13
- package/contracts/shared/PolicyHolder.sol +21 -13
- package/contracts/shared/ProxyManager.sol +2 -3
- package/contracts/shared/Registerable.sol +2 -2
- package/contracts/shared/Service.sol +32 -21
- package/contracts/shared/TokenHandler.sol +24 -1
- package/contracts/staking/IStaking.sol +168 -0
- package/contracts/staking/IStakingService.sol +98 -47
- package/contracts/staking/StakeManagerLib.sol +231 -0
- package/contracts/staking/Staking.sol +513 -0
- package/contracts/staking/StakingManager.sol +54 -0
- package/contracts/staking/StakingReader.sol +187 -0
- package/contracts/staking/StakingService.sol +286 -44
- package/contracts/staking/StakingServiceManager.sol +7 -3
- package/contracts/staking/StakingStore.sol +613 -0
- package/contracts/staking/TargetManagerLib.sol +207 -0
- package/contracts/type/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +20 -1
- package/contracts/type/Blocknumber.sol +20 -3
- package/contracts/type/Fee.sol +17 -16
- package/contracts/type/NftId.sol +14 -16
- package/contracts/type/NftIdSet.sol +1 -1
- package/contracts/type/ObjectType.sol +142 -63
- 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 +82 -20
- package/contracts/type/Seconds.sol +27 -0
- package/contracts/type/Selector.sol +102 -0
- package/contracts/type/StateId.sol +27 -2
- package/contracts/type/String.sol +53 -0
- package/contracts/type/Timestamp.sol +6 -2
- package/contracts/type/Version.sol +1 -1
- package/package.json +3 -3
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
- 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 -581
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -194
- 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/module/ITreasury.sol/ITreasury.json +0 -10
- package/contracts/instance/module/ISetup.sol +0 -33
- package/contracts/instance/module/ITreasury.sol +0 -23
@@ -3,6 +3,7 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {IAccessManaged} from "@openzeppelin/contracts/access/manager/IAccessManaged.sol";
|
5
5
|
|
6
|
+
import {Amount} from "../type/Amount.sol";
|
6
7
|
import {ClaimId} from "../type/ClaimId.sol";
|
7
8
|
import {DistributorType} from "../type/DistributorType.sol";
|
8
9
|
import {PayoutId} from "../type/PayoutId.sol";
|
@@ -13,6 +14,8 @@ import {RiskId} from "../type/RiskId.sol";
|
|
13
14
|
import {VersionPart} from "../type/Version.sol";
|
14
15
|
import {Key32} from "../type/Key32.sol";
|
15
16
|
import {RoleId} from "../type/RoleId.sol";
|
17
|
+
import {Seconds} from "../type/Seconds.sol";
|
18
|
+
import {UFixed} from "../type/UFixed.sol";
|
16
19
|
|
17
20
|
import {AccessManagerExtendedInitializeable} from "../shared/AccessManagerExtendedInitializeable.sol";
|
18
21
|
import {IRegisterable} from "../shared/IRegisterable.sol";
|
@@ -24,7 +27,7 @@ import {BundleManager} from "./BundleManager.sol";
|
|
24
27
|
import {InstanceReader} from "./InstanceReader.sol";
|
25
28
|
import {InstanceStore} from "./InstanceStore.sol";
|
26
29
|
|
27
|
-
import {IKeyValueStore} from "
|
30
|
+
import {IKeyValueStore} from "../shared/IKeyValueStore.sol";
|
28
31
|
|
29
32
|
import {IAccess} from "./module/IAccess.sol";
|
30
33
|
|
@@ -37,7 +40,6 @@ import {IPolicyService} from "../product/IPolicyService.sol";
|
|
37
40
|
import {IBundleService} from "../pool/IBundleService.sol";
|
38
41
|
|
39
42
|
|
40
|
-
|
41
43
|
interface IInstance is
|
42
44
|
IRegisterable,
|
43
45
|
ITransferInterceptor,
|
@@ -56,6 +58,10 @@ interface IInstance is
|
|
56
58
|
error ErrorInstanceInstanceStoreAlreadySet(address instanceStore);
|
57
59
|
error ErrorInstanceInstanceStoreAuthorityMismatch(address instanceAuthority);
|
58
60
|
|
61
|
+
struct InstanceInfo {
|
62
|
+
uint64 requestsCount;
|
63
|
+
}
|
64
|
+
|
59
65
|
function createRole(string memory roleName, string memory adminName) external returns (RoleId roleId, RoleId admin);
|
60
66
|
function grantRole(RoleId roleId, address account) external;
|
61
67
|
function revokeRole(RoleId roleId, address account) external;
|
@@ -64,11 +70,13 @@ interface IInstance is
|
|
64
70
|
function setTargetFunctionRole(string memory targetName, bytes4[] calldata selectors, RoleId roleId) external;
|
65
71
|
function setTargetLocked(address target, bool locked) external;
|
66
72
|
|
67
|
-
function
|
68
|
-
function
|
69
|
-
function
|
70
|
-
|
71
|
-
|
73
|
+
function setStakingLockingPeriod(Seconds stakeLockingPeriod) external;
|
74
|
+
function setStakingRewardRate(UFixed rewardRate) external;
|
75
|
+
function refillStakingRewardReserves(Amount dipAmount) external;
|
76
|
+
|
77
|
+
/// @dev defunds the staking reward reserves for the specified target
|
78
|
+
/// permissioned: only the target owner may call this function
|
79
|
+
function withdrawStakingRewardReserves(Amount dipAmount) external returns (Amount newBalance);
|
72
80
|
|
73
81
|
function getMajorVersion() external pure returns (VersionPart majorVersion);
|
74
82
|
function getInstanceReader() external view returns (InstanceReader);
|
@@ -1,21 +1,28 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
+
import {Amount} from "../type/Amount.sol";
|
5
|
+
import {BundleManager} from "./BundleManager.sol";
|
6
|
+
import {Instance} from "./Instance.sol";
|
7
|
+
import {IService} from "../shared/IService.sol";
|
4
8
|
import {NftId} from "../type/NftId.sol";
|
5
9
|
import {ObjectType} from "../type/ObjectType.sol";
|
6
10
|
import {RoleId} from "../type/RoleId.sol";
|
7
|
-
import {
|
8
|
-
|
9
|
-
import {
|
10
|
-
import {Instance} from "./Instance.sol";
|
11
|
-
import {InstanceReader} from "./InstanceReader.sol";
|
12
|
-
import {BundleManager} from "./BundleManager.sol";
|
13
|
-
import {InstanceStore} from "./InstanceStore.sol";
|
11
|
+
import {Seconds} from "../type/Seconds.sol";
|
12
|
+
import {UFixed} from "../type/UFixed.sol";
|
13
|
+
import {VersionPart} from "../type/Version.sol";
|
14
14
|
|
15
15
|
interface IInstanceService is IService {
|
16
16
|
|
17
|
+
// onlyInstance
|
18
|
+
error ErrorInstanceServiceNotRegistered(address instance);
|
19
|
+
error ErrorInstanceServiceNotInstance(address instance, ObjectType objectType);
|
20
|
+
error ErrorInstanceServiceInstanceVersionMismatch(address instance, VersionPart instanceVersion);
|
21
|
+
|
22
|
+
error ErrorInstanceServiceComponentNotInstanceLinked(address component);
|
23
|
+
|
17
24
|
error ErrorInstanceServiceMasterInstanceAlreadySet();
|
18
|
-
error
|
25
|
+
error ErrorInstanceServiceMasterInstanceAccessManagerAlreadySet();
|
19
26
|
error ErrorInstanceServiceMasterInstanceAdminAlreadySet();
|
20
27
|
error ErrorInstanceServiceMasterBundleManagerAlreadySet();
|
21
28
|
error ErrorInstanceServiceInstanceAddressZero();
|
@@ -37,8 +44,7 @@ interface IInstanceService is IService {
|
|
37
44
|
error ErrorInstanceServiceInstanceStoreAuthorityMismatch();
|
38
45
|
|
39
46
|
error ErrorInstanceServiceRequestUnauhorized(address caller);
|
40
|
-
error
|
41
|
-
error ErrorInstanceServiceNotInstance(NftId nftId);
|
47
|
+
error ErrorInstanceServiceNotInstanceNftId(NftId nftId);
|
42
48
|
error ErrorInstanceServiceComponentNotRegistered(address componentAddress);
|
43
49
|
error ErrorInstanceServiceInstanceComponentMismatch(NftId instanceNftId, NftId componentNftId);
|
44
50
|
error ErrorInstanceServiceInvalidComponentType(address componentAddress, ObjectType expectedType, ObjectType componentType);
|
@@ -56,10 +62,29 @@ interface IInstanceService is IService {
|
|
56
62
|
function createInstanceClone()
|
57
63
|
external
|
58
64
|
returns (
|
65
|
+
// TODO check if Instance can be changed to IInstance
|
59
66
|
Instance clonedInstance,
|
60
67
|
NftId instanceNftId
|
61
68
|
);
|
62
69
|
|
70
|
+
|
71
|
+
function setStakingLockingPeriod(Seconds stakeLockingPeriod) external;
|
72
|
+
function setStakingRewardRate(UFixed rewardRate) external;
|
73
|
+
function refillStakingRewardReserves(address rewardProvider, Amount dipAmount) external;
|
74
|
+
|
75
|
+
/// @dev defunds the staking reward reserves for the specified target
|
76
|
+
/// permissioned: only the target owner may call this function
|
77
|
+
function withdrawStakingRewardReserves(Amount dipAmount) external returns (Amount newBalance);
|
78
|
+
|
79
|
+
|
80
|
+
function createComponentTarget(
|
81
|
+
NftId instanceNftId,
|
82
|
+
address targetAddress,
|
83
|
+
string memory targetName,
|
84
|
+
bytes4[][] memory selectors,
|
85
|
+
RoleId[] memory roles
|
86
|
+
) external;
|
87
|
+
|
63
88
|
function createGifTarget(
|
64
89
|
NftId instanceNftId,
|
65
90
|
address targetAddress,
|
@@ -3,16 +3,19 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
5
5
|
|
6
|
+
import {Amount} from "../type/Amount.sol";
|
6
7
|
import {Key32} from "../type/Key32.sol";
|
7
8
|
import {NftId} from "../type/NftId.sol";
|
8
9
|
import {RiskId} from "../type/RiskId.sol";
|
9
10
|
import {ObjectType, BUNDLE, DISTRIBUTION, INSTANCE, POLICY, POOL, ROLE, PRODUCT, TARGET, COMPONENT, DISTRIBUTOR, DISTRIBUTOR_TYPE} from "../type/ObjectType.sol";
|
10
11
|
import {RoleId, RoleIdLib, eqRoleId, ADMIN_ROLE, INSTANCE_ROLE, INSTANCE_OWNER_ROLE} from "../type/RoleId.sol";
|
11
|
-
import {VersionPart, VersionPartLib} from "../type/Version.sol";
|
12
12
|
import {ClaimId} from "../type/ClaimId.sol";
|
13
13
|
import {ReferralId} from "../type/Referral.sol";
|
14
14
|
import {PayoutId} from "../type/PayoutId.sol";
|
15
15
|
import {DistributorType} from "../type/DistributorType.sol";
|
16
|
+
import {Seconds} from "../type/Seconds.sol";
|
17
|
+
import {UFixed} from "../type/UFixed.sol";
|
18
|
+
import {VersionPart, VersionPartLib} from "../type/Version.sol";
|
16
19
|
|
17
20
|
import {Registerable} from "../shared/Registerable.sol";
|
18
21
|
import {TokenHandler} from "../shared/TokenHandler.sol";
|
@@ -21,17 +24,19 @@ import {AccessManagerExtendedInitializeable} from "../shared/AccessManagerExtend
|
|
21
24
|
import {IRegistry} from "../registry/IRegistry.sol";
|
22
25
|
|
23
26
|
import {IInstance} from "./IInstance.sol";
|
27
|
+
import {IInstanceService} from "./IInstanceService.sol";
|
24
28
|
import {InstanceReader} from "./InstanceReader.sol";
|
25
29
|
import {InstanceAdmin} from "./InstanceAdmin.sol";
|
26
30
|
import {BundleManager} from "./BundleManager.sol";
|
27
31
|
import {InstanceStore} from "./InstanceStore.sol";
|
28
32
|
|
33
|
+
import {KeyValueStore} from "../shared/KeyValueStore.sol";
|
34
|
+
|
29
35
|
import {IBundle} from "./module/IBundle.sol";
|
30
36
|
import {IComponents} from "./module/IComponents.sol";
|
31
37
|
import {IDistribution} from "./module/IDistribution.sol";
|
32
38
|
import {IPolicy} from "./module/IPolicy.sol";
|
33
39
|
import {IRisk} from "./module/IRisk.sol";
|
34
|
-
import {ISetup} from "./module/ISetup.sol";
|
35
40
|
|
36
41
|
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
37
42
|
import {IPoolService} from "../pool/IPoolService.sol";
|
@@ -48,6 +53,7 @@ contract Instance is
|
|
48
53
|
|
49
54
|
bool private _initialized;
|
50
55
|
|
56
|
+
IInstanceService internal _instanceService;
|
51
57
|
InstanceAdmin internal _instanceAdmin;
|
52
58
|
InstanceReader internal _instanceReader;
|
53
59
|
BundleManager internal _bundleManager;
|
@@ -73,13 +79,52 @@ contract Instance is
|
|
73
79
|
IRegistry registry = IRegistry(registryAddress);
|
74
80
|
initializeRegisterable(registryAddress, registry.getNftId(), INSTANCE(), true, initialOwner, "");
|
75
81
|
|
82
|
+
_instanceService = IInstanceService(
|
83
|
+
getRegistry().getServiceAddress(
|
84
|
+
INSTANCE(),
|
85
|
+
getMajorVersion()));
|
86
|
+
|
76
87
|
registerInterface(type(IInstance).interfaceId);
|
77
88
|
}
|
78
89
|
|
90
|
+
//--- Staking ----------------------------------------------------------//
|
91
|
+
|
92
|
+
function setStakingLockingPeriod(Seconds stakeLockingPeriod)
|
93
|
+
external
|
94
|
+
// TODO decide if onlyOwner or restricted to instance owner role is better
|
95
|
+
onlyOwner()
|
96
|
+
{
|
97
|
+
_instanceService.setStakingLockingPeriod(stakeLockingPeriod);
|
98
|
+
}
|
99
|
+
|
100
|
+
function setStakingRewardRate(UFixed rewardRate)
|
101
|
+
external
|
102
|
+
onlyOwner()
|
103
|
+
{
|
104
|
+
_instanceService.setStakingRewardRate(rewardRate);
|
105
|
+
}
|
106
|
+
|
107
|
+
function refillStakingRewardReserves(Amount dipAmount)
|
108
|
+
external
|
109
|
+
onlyOwner()
|
110
|
+
{
|
111
|
+
address instanceOwner = msg.sender;
|
112
|
+
_instanceService.refillStakingRewardReserves(instanceOwner, dipAmount);
|
113
|
+
}
|
114
|
+
|
115
|
+
function withdrawStakingRewardReserves(Amount dipAmount)
|
116
|
+
external
|
117
|
+
onlyOwner()
|
118
|
+
returns (Amount newBalance)
|
119
|
+
{
|
120
|
+
return _instanceService.withdrawStakingRewardReserves(dipAmount);
|
121
|
+
}
|
122
|
+
|
79
123
|
//--- Roles ------------------------------------------------------------//
|
80
124
|
|
81
125
|
function createRole(string memory roleName, string memory adminName)
|
82
126
|
external
|
127
|
+
// TODO decide if onlyOwner or restricted to instance owner role is better
|
83
128
|
restricted // INSTANCE_OWNER_ROLE
|
84
129
|
returns (RoleId roleId, RoleId admin)
|
85
130
|
{
|
@@ -88,6 +133,7 @@ contract Instance is
|
|
88
133
|
|
89
134
|
function grantRole(RoleId roleId, address account)
|
90
135
|
external
|
136
|
+
// TODO decide if onlyOwner or restricted to instance owner role is better
|
91
137
|
restricted // INSTANCE_OWNER_ROLE
|
92
138
|
{
|
93
139
|
AccessManagerExtendedInitializeable(authority()).grantRole(roleId.toInt(), account, 0);
|
@@ -95,6 +141,7 @@ contract Instance is
|
|
95
141
|
|
96
142
|
function revokeRole(RoleId roleId, address account)
|
97
143
|
external
|
144
|
+
// TODO decide if onlyOwner or restricted to instance owner role is better
|
98
145
|
restricted // INSTANCE_OWNER_ROLE
|
99
146
|
{
|
100
147
|
AccessManagerExtendedInitializeable(authority()).revokeRole(roleId.toInt(), account);
|
@@ -104,6 +151,7 @@ contract Instance is
|
|
104
151
|
|
105
152
|
function createTarget(address target, string memory name)
|
106
153
|
external
|
154
|
+
// TODO decide if onlyOwner or restricted to instance owner role is better
|
107
155
|
restricted // INSTANCE_OWNER_ROLE
|
108
156
|
{
|
109
157
|
_instanceAdmin.createTarget(target, name);
|
@@ -127,7 +175,8 @@ contract Instance is
|
|
127
175
|
_instanceAdmin.setTargetLockedByInstance(target, locked);
|
128
176
|
}
|
129
177
|
|
130
|
-
//--- ITransferInterceptor
|
178
|
+
//--- ITransferInterceptor ----------------------------------------------//
|
179
|
+
|
131
180
|
// TODO interception of child components nfts
|
132
181
|
function nftMint(address to, uint256 tokenId) external onlyChainNft {
|
133
182
|
_instanceAdmin.transferInstanceOwnerRole(address(0), to);
|
@@ -174,6 +223,16 @@ contract Instance is
|
|
174
223
|
_instanceReader = instanceReader;
|
175
224
|
}
|
176
225
|
|
226
|
+
function setInstanceStore(InstanceStore instanceStore) external restricted {
|
227
|
+
if(address(_instanceStore) != address(0)) {
|
228
|
+
revert ErrorInstanceInstanceStoreAlreadySet(address(_instanceStore));
|
229
|
+
}
|
230
|
+
if(instanceStore.authority() != authority()) {
|
231
|
+
revert ErrorInstanceInstanceStoreAuthorityMismatch(authority());
|
232
|
+
}
|
233
|
+
_instanceStore = instanceStore;
|
234
|
+
}
|
235
|
+
|
177
236
|
//--- external view functions -------------------------------------------//
|
178
237
|
|
179
238
|
function getInstanceReader() external view returns (InstanceReader) {
|
@@ -192,43 +251,13 @@ contract Instance is
|
|
192
251
|
return AccessManagerExtendedInitializeable(authority());
|
193
252
|
}
|
194
253
|
|
195
|
-
function setInstanceStore(InstanceStore instanceStore) external restricted {
|
196
|
-
if(address(_instanceStore) != address(0)) {
|
197
|
-
revert ErrorInstanceInstanceStoreAlreadySet(address(_instanceStore));
|
198
|
-
}
|
199
|
-
if(instanceStore.authority() != authority()) {
|
200
|
-
revert ErrorInstanceInstanceStoreAuthorityMismatch(authority());
|
201
|
-
}
|
202
|
-
_instanceStore = instanceStore;
|
203
|
-
}
|
204
|
-
|
205
254
|
function getInstanceStore() external view returns (InstanceStore) {
|
206
255
|
return _instanceStore;
|
207
256
|
}
|
208
257
|
|
209
|
-
function getMajorVersion()
|
258
|
+
function getMajorVersion() public pure returns (VersionPart majorVersion) {
|
210
259
|
return VersionPartLib.toVersionPart(GIF_MAJOR_VERSION);
|
211
260
|
}
|
212
261
|
|
213
|
-
function getDistributionService() external view returns (IDistributionService) {
|
214
|
-
return IDistributionService(getRegistry().getServiceAddress(DISTRIBUTION(), VersionPart.wrap(3)));
|
215
|
-
}
|
216
|
-
|
217
|
-
function getProductService() external view returns (IProductService) {
|
218
|
-
return IProductService(getRegistry().getServiceAddress(PRODUCT(), VersionPart.wrap(3)));
|
219
|
-
}
|
220
|
-
|
221
|
-
function getPoolService() external view returns (IPoolService) {
|
222
|
-
return IPoolService(getRegistry().getServiceAddress(POOL(), VersionPart.wrap(3)));
|
223
|
-
}
|
224
|
-
|
225
|
-
function getPolicyService() external view returns (IPolicyService) {
|
226
|
-
return IPolicyService(getRegistry().getServiceAddress(POLICY(), VersionPart.wrap(3)));
|
227
|
-
}
|
228
|
-
|
229
|
-
function getBundleService() external view returns (IBundleService) {
|
230
|
-
return IBundleService(getRegistry().getServiceAddress(BUNDLE(), VersionPart.wrap(3)));
|
231
|
-
}
|
232
|
-
|
233
262
|
//--- internal view/pure functions --------------------------------------//
|
234
263
|
}
|
@@ -242,7 +242,7 @@ contract InstanceAdmin is
|
|
242
242
|
_accessManager.createRole(roleId.toInt(), name);
|
243
243
|
}
|
244
244
|
|
245
|
-
function _validateRole(RoleId roleId, IAccess.Type rtype) internal
|
245
|
+
function _validateRole(RoleId roleId, IAccess.Type rtype) internal pure
|
246
246
|
{
|
247
247
|
uint roleIdInt = roleId.toInt();
|
248
248
|
if(rtype == IAccess.Type.Custom && roleIdInt < CUSTOM_ROLE_ID_MIN) {
|
@@ -312,7 +312,8 @@ contract InstanceAdmin is
|
|
312
312
|
view
|
313
313
|
{}
|
314
314
|
|
315
|
-
// IMPORTANT: instance
|
315
|
+
// IMPORTANT: instance admin MUST be of Core type -> otherwise can be locked forever
|
316
|
+
// TODO: consider locking gif targets in a separate function?
|
316
317
|
function _setTargetLocked(address target, bool locked) internal
|
317
318
|
{
|
318
319
|
IAccess.Type targetType = _targetType[target];
|
@@ -1,8 +1,8 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {ADMIN_ROLE, INSTANCE_OWNER_ROLE, DISTRIBUTION_OWNER_ROLE, POOL_OWNER_ROLE, PRODUCT_OWNER_ROLE, INSTANCE_SERVICE_ROLE, DISTRIBUTION_SERVICE_ROLE, POOL_SERVICE_ROLE, PRODUCT_SERVICE_ROLE, APPLICATION_SERVICE_ROLE, POLICY_SERVICE_ROLE, CLAIM_SERVICE_ROLE, BUNDLE_SERVICE_ROLE, INSTANCE_ROLE} from "../type/RoleId.sol";
|
5
|
-
import {
|
4
|
+
import {ADMIN_ROLE, INSTANCE_OWNER_ROLE, ORACLE_SERVICE_ROLE, DISTRIBUTION_OWNER_ROLE, POOL_OWNER_ROLE, PRODUCT_OWNER_ROLE, ORACLE_OWNER_ROLE, INSTANCE_SERVICE_ROLE, COMPONENT_SERVICE_ROLE, DISTRIBUTION_SERVICE_ROLE, POOL_SERVICE_ROLE, PRODUCT_SERVICE_ROLE, APPLICATION_SERVICE_ROLE, POLICY_SERVICE_ROLE, CLAIM_SERVICE_ROLE, BUNDLE_SERVICE_ROLE, INSTANCE_ROLE} from "../type/RoleId.sol";
|
5
|
+
import {APPLICATION, BUNDLE, CLAIM, COMPONENT, DISTRIBUTION, INSTANCE, ORACLE, POLICY, POOL, PRODUCT, REGISTRY} from "../type/ObjectType.sol";
|
6
6
|
import {VersionPart} from "../type/Version.sol";
|
7
7
|
|
8
8
|
import {IRegistry} from "../registry/IRegistry.sol";
|
@@ -30,6 +30,8 @@ library InstanceAuthorizationsLib
|
|
30
30
|
{
|
31
31
|
_createRoles(instanceAdmin);
|
32
32
|
_createTargets(instanceAdmin, instance, bundleManager, instanceStore);
|
33
|
+
_grantComponentServiceAuthorizations(accessManager, instanceAdmin, instanceStore, registry, majorVersion);
|
34
|
+
_grantOracleServiceAuthorizations(accessManager, instanceAdmin, instanceStore, registry, majorVersion);
|
33
35
|
_grantDistributionServiceAuthorizations(accessManager, instanceAdmin, instanceStore, registry, majorVersion);
|
34
36
|
_grantPoolServiceAuthorizations(accessManager, instanceAdmin, instanceStore, registry, majorVersion);
|
35
37
|
_grantProductServiceAuthorizations(accessManager, instanceAdmin, instanceStore, registry, majorVersion);
|
@@ -46,15 +48,19 @@ library InstanceAuthorizationsLib
|
|
46
48
|
// default roles controlled by ADMIN_ROLE -> core roles
|
47
49
|
// all set/granted only once during cloning (the only exception is INSTANCE_OWNER_ROLE, hooked to instance nft)
|
48
50
|
instanceAdmin.createCoreRole(INSTANCE_SERVICE_ROLE(), "InstanceServiceRole");
|
51
|
+
instanceAdmin.createCoreRole(COMPONENT_SERVICE_ROLE(), "ComponentServiceRole");
|
49
52
|
instanceAdmin.createCoreRole(DISTRIBUTION_SERVICE_ROLE(), "DistributionServiceRole");
|
53
|
+
instanceAdmin.createCoreRole(ORACLE_SERVICE_ROLE(), "OracleServiceRole");
|
50
54
|
instanceAdmin.createCoreRole(POOL_SERVICE_ROLE(), "PoolServiceRole");
|
51
55
|
instanceAdmin.createCoreRole(APPLICATION_SERVICE_ROLE(), "ApplicationServiceRole");
|
52
56
|
instanceAdmin.createCoreRole(PRODUCT_SERVICE_ROLE(), "ProductServiceRole");
|
53
57
|
instanceAdmin.createCoreRole(CLAIM_SERVICE_ROLE(), "ClaimServiceRole");
|
54
58
|
instanceAdmin.createCoreRole(POLICY_SERVICE_ROLE(), "PolicyServiceRole");
|
55
59
|
instanceAdmin.createCoreRole(BUNDLE_SERVICE_ROLE(), "BundleServiceRole");
|
60
|
+
|
56
61
|
// default roles controlled by INSTANCE_OWNER_ROLE -> gif roles
|
57
62
|
instanceAdmin.createGifRole(DISTRIBUTION_OWNER_ROLE(), "DistributionOwnerRole", INSTANCE_OWNER_ROLE());
|
63
|
+
instanceAdmin.createGifRole(ORACLE_OWNER_ROLE(), "OracleOwnerRole", INSTANCE_OWNER_ROLE());
|
58
64
|
instanceAdmin.createGifRole(POOL_OWNER_ROLE(), "PoolOwnerRole", INSTANCE_OWNER_ROLE());
|
59
65
|
instanceAdmin.createGifRole(PRODUCT_OWNER_ROLE(), "ProductOwnerRole", INSTANCE_OWNER_ROLE());
|
60
66
|
}
|
@@ -72,29 +78,81 @@ library InstanceAuthorizationsLib
|
|
72
78
|
instanceAdmin.createCoreTarget(address(instanceStore), "InstanceStore");
|
73
79
|
}
|
74
80
|
|
75
|
-
function
|
81
|
+
function _grantComponentServiceAuthorizations(
|
76
82
|
AccessManagerExtendedInitializeable accessManager,
|
77
83
|
InstanceAdmin instanceAdmin,
|
78
84
|
InstanceStore instanceStore,
|
79
85
|
IRegistry registry,
|
80
86
|
VersionPart majorVersion)
|
81
87
|
private
|
88
|
+
{
|
89
|
+
// configure authorization for component service on instance store
|
90
|
+
address componentServiceAddress = registry.getServiceAddress(COMPONENT(), majorVersion);
|
91
|
+
accessManager.grantRole(COMPONENT_SERVICE_ROLE().toInt(), componentServiceAddress, 0);
|
92
|
+
|
93
|
+
bytes4[] memory serviceSelectors = new bytes4[](8);
|
94
|
+
serviceSelectors[0] = instanceStore.createComponent.selector;
|
95
|
+
serviceSelectors[1] = instanceStore.updateComponent.selector;
|
96
|
+
serviceSelectors[2] = instanceStore.createPool.selector;
|
97
|
+
serviceSelectors[3] = instanceStore.createProduct.selector;
|
98
|
+
serviceSelectors[5] = instanceStore.updateProduct.selector;
|
99
|
+
serviceSelectors[6] = instanceStore.increaseBalance.selector;
|
100
|
+
serviceSelectors[7] = instanceStore.increaseFees.selector;
|
101
|
+
|
102
|
+
instanceAdmin.setTargetFunctionRoleByService(
|
103
|
+
"InstanceStore",
|
104
|
+
serviceSelectors,
|
105
|
+
COMPONENT_SERVICE_ROLE());
|
106
|
+
}
|
107
|
+
|
108
|
+
function _grantOracleServiceAuthorizations(
|
109
|
+
AccessManagerExtendedInitializeable accessManager,
|
110
|
+
InstanceAdmin instanceAdmin,
|
111
|
+
InstanceStore instanceStore,
|
112
|
+
IRegistry registry,
|
113
|
+
VersionPart majorVersion
|
114
|
+
)
|
115
|
+
private
|
116
|
+
{
|
117
|
+
// configure authorization for distribution service on instance
|
118
|
+
address oracleServiceAddress = registry.getServiceAddress(ORACLE(), majorVersion);
|
119
|
+
accessManager.grantRole(ORACLE_SERVICE_ROLE().toInt(), oracleServiceAddress, 0);
|
120
|
+
|
121
|
+
bytes4[] memory instanceOracleServiceSelectors = new bytes4[](3);
|
122
|
+
instanceOracleServiceSelectors[0] = instanceStore.createRequest.selector;
|
123
|
+
instanceOracleServiceSelectors[1] = instanceStore.updateRequest.selector;
|
124
|
+
instanceOracleServiceSelectors[2] = instanceStore.updateRequestState.selector;
|
125
|
+
|
126
|
+
instanceAdmin.setTargetFunctionRoleByService(
|
127
|
+
"InstanceStore",
|
128
|
+
instanceOracleServiceSelectors,
|
129
|
+
ORACLE_SERVICE_ROLE());
|
130
|
+
}
|
131
|
+
|
132
|
+
function _grantDistributionServiceAuthorizations(
|
133
|
+
AccessManagerExtendedInitializeable accessManager,
|
134
|
+
InstanceAdmin instanceAdmin,
|
135
|
+
InstanceStore instanceStore,
|
136
|
+
IRegistry registry,
|
137
|
+
VersionPart majorVersion
|
138
|
+
)
|
139
|
+
private
|
82
140
|
{
|
83
141
|
// configure authorization for distribution service on instance
|
84
142
|
address distributionServiceAddress = registry.getServiceAddress(DISTRIBUTION(), majorVersion);
|
85
143
|
accessManager.grantRole(DISTRIBUTION_SERVICE_ROLE().toInt(), distributionServiceAddress, 0);
|
86
|
-
bytes4[] memory instanceDistributionServiceSelectors = new bytes4[](
|
87
|
-
instanceDistributionServiceSelectors[0] = instanceStore.createDistributionSetup.selector;
|
88
|
-
instanceDistributionServiceSelectors[1] = instanceStore.updateDistributionSetup.selector;
|
89
|
-
instanceDistributionServiceSelectors[
|
90
|
-
instanceDistributionServiceSelectors[
|
91
|
-
instanceDistributionServiceSelectors[
|
92
|
-
instanceDistributionServiceSelectors[
|
93
|
-
instanceDistributionServiceSelectors[
|
94
|
-
instanceDistributionServiceSelectors[
|
95
|
-
instanceDistributionServiceSelectors[
|
96
|
-
instanceDistributionServiceSelectors[
|
97
|
-
instanceDistributionServiceSelectors[
|
144
|
+
bytes4[] memory instanceDistributionServiceSelectors = new bytes4[](9);
|
145
|
+
//instanceDistributionServiceSelectors[0] = instanceStore.createDistributionSetup.selector;
|
146
|
+
//instanceDistributionServiceSelectors[1] = instanceStore.updateDistributionSetup.selector;
|
147
|
+
instanceDistributionServiceSelectors[0] = instanceStore.createDistributorType.selector;
|
148
|
+
instanceDistributionServiceSelectors[1] = instanceStore.updateDistributorType.selector;
|
149
|
+
instanceDistributionServiceSelectors[2] = instanceStore.updateDistributorTypeState.selector;
|
150
|
+
instanceDistributionServiceSelectors[3] = instanceStore.createDistributor.selector;
|
151
|
+
instanceDistributionServiceSelectors[4] = instanceStore.updateDistributor.selector;
|
152
|
+
instanceDistributionServiceSelectors[5] = instanceStore.updateDistributorState.selector;
|
153
|
+
instanceDistributionServiceSelectors[6] = instanceStore.createReferral.selector;
|
154
|
+
instanceDistributionServiceSelectors[7] = instanceStore.updateReferral.selector;
|
155
|
+
instanceDistributionServiceSelectors[8] = instanceStore.updateReferralState.selector;
|
98
156
|
instanceAdmin.setTargetFunctionRoleByService(
|
99
157
|
"InstanceStore",
|
100
158
|
instanceDistributionServiceSelectors,
|
@@ -112,9 +170,8 @@ library InstanceAuthorizationsLib
|
|
112
170
|
// configure authorization for pool service on instance
|
113
171
|
address poolServiceAddress = registry.getServiceAddress(POOL(), majorVersion);
|
114
172
|
accessManager.grantRole(POOL_SERVICE_ROLE().toInt(), address(poolServiceAddress), 0);
|
115
|
-
bytes4[] memory instancePoolServiceSelectors = new bytes4[](4)
|
116
|
-
instancePoolServiceSelectors[0] = instanceStore.
|
117
|
-
instancePoolServiceSelectors[1] = instanceStore.updatePoolSetup.selector;
|
173
|
+
bytes4[] memory instancePoolServiceSelectors = new bytes4[](1); // TODO works with (4)
|
174
|
+
instancePoolServiceSelectors[0] = instanceStore.updatePool.selector;
|
118
175
|
instanceAdmin.setTargetFunctionRoleByService(
|
119
176
|
"InstanceStore",
|
120
177
|
instancePoolServiceSelectors,
|
@@ -131,13 +188,11 @@ library InstanceAuthorizationsLib
|
|
131
188
|
{
|
132
189
|
// configure authorization for product service on instance
|
133
190
|
address productServiceAddress = registry.getServiceAddress(PRODUCT(), majorVersion);
|
134
|
-
accessManager.grantRole(PRODUCT_SERVICE_ROLE().toInt(),
|
135
|
-
bytes4[] memory instanceProductServiceSelectors = new bytes4[](
|
136
|
-
instanceProductServiceSelectors[0] = instanceStore.
|
137
|
-
instanceProductServiceSelectors[1] = instanceStore.
|
138
|
-
instanceProductServiceSelectors[2] = instanceStore.
|
139
|
-
instanceProductServiceSelectors[3] = instanceStore.updateRisk.selector;
|
140
|
-
instanceProductServiceSelectors[4] = instanceStore.updateRiskState.selector;
|
191
|
+
accessManager.grantRole(PRODUCT_SERVICE_ROLE().toInt(), productServiceAddress, 0);
|
192
|
+
bytes4[] memory instanceProductServiceSelectors = new bytes4[](3);
|
193
|
+
instanceProductServiceSelectors[0] = instanceStore.createRisk.selector;
|
194
|
+
instanceProductServiceSelectors[1] = instanceStore.updateRisk.selector;
|
195
|
+
instanceProductServiceSelectors[2] = instanceStore.updateRiskState.selector;
|
141
196
|
instanceAdmin.setTargetFunctionRoleByService(
|
142
197
|
"InstanceStore",
|
143
198
|
instanceProductServiceSelectors,
|
@@ -226,11 +281,13 @@ library InstanceAuthorizationsLib
|
|
226
281
|
{
|
227
282
|
// configure authorization for bundle service on instance
|
228
283
|
address bundleServiceAddress = registry.getServiceAddress(BUNDLE(), majorVersion);
|
229
|
-
accessManager.grantRole(BUNDLE_SERVICE_ROLE().toInt(),
|
230
|
-
bytes4[] memory instanceBundleServiceSelectors = new bytes4[](
|
284
|
+
accessManager.grantRole(BUNDLE_SERVICE_ROLE().toInt(), bundleServiceAddress, 0);
|
285
|
+
bytes4[] memory instanceBundleServiceSelectors = new bytes4[](5);
|
231
286
|
instanceBundleServiceSelectors[0] = instanceStore.createBundle.selector;
|
232
287
|
instanceBundleServiceSelectors[1] = instanceStore.updateBundle.selector;
|
233
288
|
instanceBundleServiceSelectors[2] = instanceStore.updateBundleState.selector;
|
289
|
+
instanceBundleServiceSelectors[3] = instanceStore.increaseLocked.selector;
|
290
|
+
instanceBundleServiceSelectors[4] = instanceStore.decreaseLocked.selector;
|
234
291
|
instanceAdmin.setTargetFunctionRoleByService(
|
235
292
|
"InstanceStore",
|
236
293
|
instanceBundleServiceSelectors,
|