@etherisc/gif-next 0.0.2-fd4931b-974 → 0.0.2-fd5f17a-625
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 +51 -5
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +1253 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +1206 -0
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +358 -0
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.json +10 -0
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +1032 -0
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +258 -0
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.json +290 -0
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +148 -0
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +390 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +190 -0
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +1342 -0
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +410 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +65 -463
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +291 -234
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +88 -100
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +102 -165
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +171 -47
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1411 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1171 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1517 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +1978 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +4 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +703 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +77 -78
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +149 -52
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +75 -205
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1626 -0
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +601 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +410 -130
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +191 -206
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +60 -92
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +387 -268
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/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/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +182 -0
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +181 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +8 -116
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.json +2 -2
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +979 -0
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +418 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +52 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +765 -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 +871 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +922 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +679 -0
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +1248 -0
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +410 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +440 -169
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +132 -84
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +225 -2
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +56 -295
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +255 -101
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +102 -627
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +309 -251
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +57 -81
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +72 -160
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +55 -87
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +1096 -0
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +410 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +229 -168
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +82 -94
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +25 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +134 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +204 -120
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +63 -44
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +43 -84
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
- package/artifacts/contracts/product/{IProductService.sol/IProductService.json → IRiskService.sol/IRiskService.json} +22 -3
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +273 -301
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +77 -93
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +134 -243
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +70 -110
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +53 -390
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +583 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +651 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +59 -16
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +302 -61
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +31 -184
- 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 +645 -123
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1861 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +66 -124
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +46 -81
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +164 -0
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1169 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +214 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +46 -177
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +18 -223
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +271 -164
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +83 -95
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +14 -107
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +11 -31
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +180 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +43 -42
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +11 -15
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +0 -5
- 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 +0 -42
- 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/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +4 -0
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +53 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +50 -287
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +15 -99
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +4 -65
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +4 -0
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +306 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +10 -55
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +4 -136
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +11 -94
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +14 -107
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +330 -11
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +108 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +273 -605
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +471 -62
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +440 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +332 -1004
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +164 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +73 -203
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +368 -39
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +484 -213
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +57 -84
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2242 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +318 -19
- 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 +97 -4
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +40 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +4 -4
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +4 -4
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +17 -12
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +28 -4
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +149 -2
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +4 -4
- 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 +4 -4
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +219 -6
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +100 -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 +36 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/MathLib.json +9 -3
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +58 -2
- 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 +21 -2
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +4 -0
- package/artifacts/contracts/{shared → upgradeability}/IVersionable.sol/IVersionable.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +566 -0
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +129 -0
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +4 -0
- package/artifacts/contracts/{shared → upgradeability}/Versionable.sol/Versionable.json +1 -1
- package/contracts/authorization/AccessAdmin.sol +589 -0
- package/contracts/authorization/AccessManagerCloneable.sol +16 -0
- package/contracts/authorization/Authorization.sol +217 -0
- package/contracts/authorization/IAccess.sol +48 -0
- package/contracts/authorization/IAccessAdmin.sol +136 -0
- package/contracts/authorization/IAuthorization.sol +54 -0
- package/contracts/authorization/IModuleAuthorization.sol +21 -0
- package/contracts/authorization/IServiceAuthorization.sol +38 -0
- package/contracts/authorization/ModuleAuthorization.sol +78 -0
- package/contracts/authorization/ServiceAuthorization.sol +90 -0
- package/contracts/distribution/BasicDistribution.sol +138 -0
- package/contracts/distribution/BasicDistributionAuthorization.sol +47 -0
- package/contracts/distribution/Distribution.sol +146 -114
- package/contracts/distribution/DistributionService.sol +84 -46
- package/contracts/distribution/DistributionServiceManager.sol +2 -17
- package/contracts/distribution/IDistributionComponent.sol +26 -40
- package/contracts/distribution/IDistributionService.sol +24 -4
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +50 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +137 -0
- package/contracts/examples/unpermissioned/SimplePool.sol +76 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +351 -0
- package/contracts/instance/{BundleManager.sol → BundleSet.sol} +23 -23
- package/contracts/instance/IInstance.sol +29 -43
- package/contracts/instance/IInstanceService.sol +36 -27
- package/contracts/instance/Instance.sol +117 -116
- package/contracts/instance/InstanceAdmin.sol +285 -0
- package/contracts/instance/InstanceAuthorizationV3.sol +204 -0
- package/contracts/instance/InstanceReader.sol +82 -18
- package/contracts/instance/InstanceService.sol +206 -106
- package/contracts/instance/InstanceServiceManager.sol +2 -6
- package/contracts/instance/InstanceStore.sol +49 -22
- package/contracts/instance/base/BalanceStore.sol +11 -6
- package/contracts/instance/base/Cloneable.sol +2 -25
- package/contracts/instance/base/ObjectCounter.sol +21 -0
- package/contracts/instance/base/ObjectLifecycle.sol +111 -0
- package/contracts/instance/base/{ObjectManager.sol → ObjectSet.sol} +11 -14
- package/contracts/instance/module/IAccess.sol +2 -10
- package/contracts/instance/module/IBundle.sol +1 -1
- package/contracts/instance/module/IComponents.sol +1 -7
- package/contracts/instance/module/IDistribution.sol +0 -1
- package/contracts/instance/module/IPolicy.sol +22 -22
- package/contracts/mock/Dip.sol +1 -1
- package/contracts/oracle/BasicOracle.sol +48 -0
- package/contracts/oracle/BasicOracleAuthorization.sol +46 -0
- package/contracts/oracle/IOracle.sol +36 -0
- package/contracts/oracle/IOracleComponent.sol +33 -0
- package/contracts/oracle/IOracleService.sol +65 -0
- package/contracts/oracle/Oracle.sol +167 -0
- package/contracts/oracle/OracleService.sol +279 -0
- package/contracts/oracle/OracleServiceManager.sol +39 -0
- package/contracts/pool/BasicPool.sol +166 -0
- package/contracts/pool/BasicPoolAuthorization.sol +58 -0
- package/contracts/pool/BundleService.sol +211 -69
- package/contracts/pool/BundleServiceManager.sol +2 -5
- package/contracts/pool/IBundleService.sol +34 -6
- package/contracts/pool/IPoolComponent.sol +6 -60
- package/contracts/pool/IPoolService.sol +40 -27
- package/contracts/pool/Pool.sol +165 -138
- package/contracts/pool/PoolService.sol +199 -114
- package/contracts/pool/PoolServiceManager.sol +2 -5
- package/contracts/product/ApplicationService.sol +59 -65
- package/contracts/product/ApplicationServiceManager.sol +2 -2
- package/contracts/product/BasicProduct.sol +53 -0
- package/contracts/product/BasicProductAuthorization.sol +43 -0
- package/contracts/product/ClaimService.sol +132 -82
- package/contracts/product/ClaimServiceManager.sol +2 -2
- package/contracts/product/IApplicationService.sol +2 -1
- package/contracts/product/IClaimService.sol +32 -3
- package/contracts/product/IPolicyService.sol +28 -33
- package/contracts/product/IPricingService.sol +8 -8
- package/contracts/product/IProductComponent.sol +7 -10
- package/contracts/product/{IProductService.sol → IRiskService.sol} +2 -2
- package/contracts/product/PolicyService.sol +289 -189
- package/contracts/product/PolicyServiceManager.sol +2 -5
- package/contracts/product/PricingService.sol +52 -52
- package/contracts/product/PricingServiceManager.sol +2 -5
- package/contracts/product/Product.sol +163 -115
- package/contracts/product/{ProductService.sol → RiskService.sol} +18 -45
- package/contracts/product/RiskServiceManager.sol +39 -0
- package/contracts/registry/ChainNft.sol +65 -31
- package/contracts/registry/IRegistry.sol +79 -29
- package/contracts/registry/IRegistryService.sol +7 -6
- package/contracts/registry/Registry.sol +354 -215
- package/contracts/registry/RegistryAdmin.sol +464 -0
- package/contracts/registry/RegistryService.sol +14 -90
- package/contracts/registry/RegistryServiceManager.sol +3 -22
- package/contracts/registry/ReleaseLifecycle.sol +27 -0
- package/contracts/registry/ReleaseRegistry.sol +491 -0
- package/contracts/registry/ServiceAuthorizationV3.sol +199 -0
- package/contracts/registry/TokenRegistry.sol +58 -62
- package/contracts/shared/Component.sol +35 -53
- package/contracts/shared/ComponentService.sol +127 -81
- package/contracts/shared/ComponentServiceManager.sol +2 -2
- package/contracts/shared/ComponentVerifyingService.sol +14 -8
- package/contracts/shared/IComponent.sol +7 -11
- package/contracts/shared/IComponentService.sol +26 -9
- package/contracts/shared/IInstanceLinkedComponent.sol +10 -7
- package/contracts/shared/IKeyValueStore.sol +2 -1
- package/contracts/shared/ILifecycle.sol +1 -2
- package/contracts/shared/INftOwnable.sol +1 -1
- package/contracts/shared/IPolicyHolder.sol +0 -9
- package/contracts/shared/IService.sol +9 -2
- package/contracts/shared/InitializableCustom.sol +177 -0
- package/contracts/shared/{ERC165.sol → InitializableERC165.sol} +4 -4
- package/contracts/shared/InstanceLinkedComponent.sol +51 -24
- package/contracts/shared/KeyValueStore.sol +7 -6
- package/contracts/shared/Lifecycle.sol +16 -60
- package/contracts/shared/{NftIdSetManager.sol → NftIdSet.sol} +3 -7
- package/contracts/shared/NftOwnable.sol +9 -20
- package/contracts/shared/PolicyHolder.sol +8 -53
- package/contracts/shared/Registerable.sol +4 -4
- package/contracts/shared/RegistryLinked.sol +3 -2
- package/contracts/shared/Service.sol +33 -28
- package/contracts/shared/TokenHandler.sol +100 -19
- package/contracts/shared/TokenHandlerDeployerLib.sol +12 -0
- package/contracts/staking/IStaking.sol +96 -41
- package/contracts/staking/IStakingService.sol +78 -40
- package/contracts/staking/StakeManagerLib.sol +224 -0
- package/contracts/staking/Staking.sol +305 -155
- package/contracts/staking/StakingLifecycle.sol +23 -0
- package/contracts/staking/StakingManager.sol +21 -23
- package/contracts/staking/StakingReader.sol +119 -28
- package/contracts/staking/StakingService.sol +190 -77
- package/contracts/staking/StakingServiceManager.sol +4 -4
- package/contracts/staking/StakingStore.sol +605 -0
- package/contracts/staking/TargetManagerLib.sol +83 -13
- package/contracts/type/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +24 -3
- package/contracts/type/Blocknumber.sol +20 -2
- package/contracts/type/Fee.sol +1 -1
- package/contracts/type/NftId.sol +9 -9
- package/contracts/type/NftIdSet.sol +1 -1
- package/contracts/type/ObjectType.sol +174 -68
- package/contracts/type/Referral.sol +2 -1
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/type/RiskId.sol +1 -1
- package/contracts/type/RoleId.sol +104 -73
- package/contracts/type/Seconds.sol +39 -1
- package/contracts/type/Selector.sol +102 -0
- package/contracts/type/StateId.sol +13 -0
- package/contracts/type/String.sol +53 -0
- package/contracts/type/Timestamp.sol +17 -3
- package/contracts/type/UFixed.sol +34 -9
- package/contracts/type/Version.sol +4 -2
- package/contracts/{shared → upgradeability}/ProxyManager.sol +9 -6
- package/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol +1 -3
- package/package.json +8 -5
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +0 -4
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +0 -778
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1348
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +0 -132
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +0 -256
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +0 -673
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +0 -675
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -298
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +0 -4
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +0 -1112
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +0 -4
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +0 -137
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +0 -4
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +0 -73
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +0 -4
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +0 -4
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +0 -314
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +0 -4
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -598
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +0 -4
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +0 -129
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +0 -4
- package/contracts/instance/InstanceAccessManager.sol +0 -543
- package/contracts/instance/InstanceAuthorizationsLib.sol +0 -336
- package/contracts/product/ProductServiceManager.sol +0 -42
- package/contracts/registry/RegistryAccessManager.sol +0 -167
- package/contracts/registry/ReleaseManager.sol +0 -530
- package/contracts/registry/ServiceAuthorizationsLib.sol +0 -173
- package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +0 -13
- /package/contracts/{shared → upgradeability}/IVersionable.sol +0 -0
- /package/contracts/{shared → upgradeability}/Versionable.sol +0 -0
@@ -0,0 +1,285 @@
|
|
1
|
+
// SPDX-License-Identifier: UNLICENSED
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {AccessManager} from "@openzeppelin/contracts/access/manager/AccessManager.sol";
|
5
|
+
|
6
|
+
import {AccessAdmin} from "../authorization/AccessAdmin.sol";
|
7
|
+
import {AccessManagerCloneable} from "../authorization/AccessManagerCloneable.sol";
|
8
|
+
import {IAccessAdmin} from "../authorization/IAccessAdmin.sol";
|
9
|
+
import {IAuthorization} from "../authorization/IAuthorization.sol";
|
10
|
+
import {IComponent} from "../shared/IComponent.sol";
|
11
|
+
import {IModuleAuthorization} from "../authorization/IModuleAuthorization.sol";
|
12
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
13
|
+
import {IInstance} from "./IInstance.sol";
|
14
|
+
import {IService} from "../shared/IService.sol";
|
15
|
+
import {ObjectType, ObjectTypeLib, ALL, POOL, RELEASE} from "../type/ObjectType.sol";
|
16
|
+
import {RoleId, RoleIdLib, ADMIN_ROLE, PUBLIC_ROLE, DISTRIBUTION_OWNER_ROLE, ORACLE_OWNER_ROLE, POOL_OWNER_ROLE, PRODUCT_OWNER_ROLE} from "../type/RoleId.sol";
|
17
|
+
import {Str, StrLib} from "../type/String.sol";
|
18
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
19
|
+
import {VersionPart} from "../type/Version.sol";
|
20
|
+
|
21
|
+
|
22
|
+
contract InstanceAdmin is
|
23
|
+
AccessAdmin
|
24
|
+
{
|
25
|
+
string public constant INSTANCE_TARGET_NAME = "Instance";
|
26
|
+
string public constant INSTANCE_STORE_TARGET_NAME = "InstanceStore";
|
27
|
+
string public constant INSTANCE_ADMIN_TARGET_NAME = "InstanceAdmin";
|
28
|
+
string public constant BUNDLE_SET_TARGET_NAME = "BundleSet";
|
29
|
+
|
30
|
+
uint64 public constant CUSTOM_ROLE_ID_MIN = 10000; // MUST be even
|
31
|
+
|
32
|
+
error ErrorInstanceAdminNotRegistered(address target);
|
33
|
+
error ErrorInstanceAdminAlreadyAuthorized(address target);
|
34
|
+
error ErrorInstanceAdminReleaseMismatch();
|
35
|
+
error ErrorInstanceAdminExpectedTargetMissing(string targetName);
|
36
|
+
|
37
|
+
IInstance _instance;
|
38
|
+
IRegistry internal _registry;
|
39
|
+
uint64 _idNext;
|
40
|
+
|
41
|
+
IModuleAuthorization _instanceAuthorization;
|
42
|
+
|
43
|
+
/// @dev Only used for master instance admin.
|
44
|
+
/// Contracts created via constructor come with disabled initializers.
|
45
|
+
constructor(
|
46
|
+
IModuleAuthorization instanceAuthorization
|
47
|
+
)
|
48
|
+
AccessAdmin()
|
49
|
+
{
|
50
|
+
_instanceAuthorization = instanceAuthorization;
|
51
|
+
}
|
52
|
+
|
53
|
+
/// @dev Initializes this instance admin with the provided instances authorization specification.
|
54
|
+
/// Internally the function creates an instance specific OpenZeppelin AccessManager that is used as the authority
|
55
|
+
/// for the inststance authorizatios.
|
56
|
+
/// Important: Initialization of this instance admin is only complete after calling function initializeInstance.
|
57
|
+
function initialize(
|
58
|
+
AccessManagerCloneable accessManager,
|
59
|
+
IModuleAuthorization instanceAuthorization
|
60
|
+
)
|
61
|
+
external
|
62
|
+
initializer()
|
63
|
+
{
|
64
|
+
// create new access manager for this instance admin
|
65
|
+
_initializeAuthority(address(accessManager));
|
66
|
+
|
67
|
+
// create basic instance independent setup
|
68
|
+
_createAdminAndPublicRoles();
|
69
|
+
|
70
|
+
// store instance authorization specification
|
71
|
+
_instanceAuthorization = IModuleAuthorization(instanceAuthorization);
|
72
|
+
}
|
73
|
+
|
74
|
+
function _checkTargetIsReadyForAuthorization(address target)
|
75
|
+
internal
|
76
|
+
view
|
77
|
+
{
|
78
|
+
if (address(_registry) != address(0) && !_registry.isRegistered(target)) {
|
79
|
+
revert ErrorInstanceAdminNotRegistered(target);
|
80
|
+
}
|
81
|
+
|
82
|
+
if (targetExists(target)) {
|
83
|
+
revert ErrorInstanceAdminAlreadyAuthorized(target);
|
84
|
+
}
|
85
|
+
}
|
86
|
+
|
87
|
+
/// @dev Completes the initialization of this instance admin using the provided instance.
|
88
|
+
/// Important: The instance MUST be registered and all instance supporting contracts must be wired to this instance.
|
89
|
+
function initializeInstanceAuthorization(address instanceAddress)
|
90
|
+
external
|
91
|
+
{
|
92
|
+
_checkTargetIsReadyForAuthorization(instanceAddress);
|
93
|
+
|
94
|
+
_idNext = CUSTOM_ROLE_ID_MIN;
|
95
|
+
_instance = IInstance(instanceAddress);
|
96
|
+
_registry = _instance.getRegistry();
|
97
|
+
|
98
|
+
// check matching releases
|
99
|
+
if (_instanceAuthorization.getRelease() != _instance.getMajorVersion()) {
|
100
|
+
revert ErrorInstanceAdminReleaseMismatch();
|
101
|
+
}
|
102
|
+
|
103
|
+
// add instance authorization
|
104
|
+
_createRoles(_instanceAuthorization);
|
105
|
+
_createModuleTargetsWithRoles();
|
106
|
+
_createTargetAuthorizations(_instanceAuthorization);
|
107
|
+
|
108
|
+
// grant component owner roles to instance owner
|
109
|
+
_grantComponentOwnerRoles();
|
110
|
+
}
|
111
|
+
|
112
|
+
|
113
|
+
/// @dev Initializes the authorization for the specified component.
|
114
|
+
/// Important: The component MUST be registered.
|
115
|
+
function initializeComponentAuthorization(
|
116
|
+
IComponent component,
|
117
|
+
IAuthorization authorization
|
118
|
+
)
|
119
|
+
external
|
120
|
+
{
|
121
|
+
_checkTargetIsReadyForAuthorization(address(component));
|
122
|
+
|
123
|
+
_createRoles(authorization);
|
124
|
+
|
125
|
+
// create component target
|
126
|
+
_createTarget(
|
127
|
+
address(component),
|
128
|
+
authorization.getTargetName(),
|
129
|
+
true, // checkAuthority
|
130
|
+
false); // custom
|
131
|
+
|
132
|
+
_createTarget(
|
133
|
+
address(component.getTokenHandler()),
|
134
|
+
string(abi.encodePacked(authorization.getTargetName(), "TH")),
|
135
|
+
true,
|
136
|
+
false);
|
137
|
+
|
138
|
+
// FIXME: make this a bit nicer and work with IAuthorization. Use a specific role, not public - access to TokenHandler must be restricted
|
139
|
+
FunctionInfo[] memory functions = new FunctionInfo[](3);
|
140
|
+
functions[0] = toFunction(TokenHandler.collectTokens.selector, "collectTokens");
|
141
|
+
functions[1] = toFunction(TokenHandler.collectTokensToThreeRecipients.selector, "collectTokensToThreeRecipients");
|
142
|
+
functions[2] = toFunction(TokenHandler.distributeTokens.selector, "distributeTokens");
|
143
|
+
|
144
|
+
_authorizeTargetFunctions(
|
145
|
+
address(component.getTokenHandler()),
|
146
|
+
getPublicRole(),
|
147
|
+
functions);
|
148
|
+
|
149
|
+
_grantRoleToAccount(
|
150
|
+
authorization.getTargetRole(
|
151
|
+
authorization.getTarget()),
|
152
|
+
address(component));
|
153
|
+
|
154
|
+
_createTargetAuthorizations(authorization);
|
155
|
+
}
|
156
|
+
|
157
|
+
|
158
|
+
function _grantComponentOwnerRoles()
|
159
|
+
internal
|
160
|
+
{
|
161
|
+
address instanceOwner = _registry.ownerOf(_instance.getNftId());
|
162
|
+
_grantRoleToAccount(DISTRIBUTION_OWNER_ROLE(), instanceOwner);
|
163
|
+
_grantRoleToAccount(ORACLE_OWNER_ROLE(), instanceOwner);
|
164
|
+
_grantRoleToAccount(POOL_OWNER_ROLE(), instanceOwner);
|
165
|
+
_grantRoleToAccount(PRODUCT_OWNER_ROLE(), instanceOwner);
|
166
|
+
}
|
167
|
+
|
168
|
+
/// @dev Creates a custom role
|
169
|
+
// TODO implement
|
170
|
+
// function createRole()
|
171
|
+
// external
|
172
|
+
// restricted()
|
173
|
+
// {
|
174
|
+
|
175
|
+
// }
|
176
|
+
|
177
|
+
/// @dev Grants the provided role to the specified account
|
178
|
+
function grantRole(
|
179
|
+
RoleId roleId,
|
180
|
+
address account)
|
181
|
+
external
|
182
|
+
restricted()
|
183
|
+
{
|
184
|
+
_grantRoleToAccount(roleId, account);
|
185
|
+
}
|
186
|
+
|
187
|
+
/// @dev Returns the instance authorization specification used to set up this instance admin.
|
188
|
+
function getInstanceAuthorization()
|
189
|
+
external
|
190
|
+
view
|
191
|
+
returns (IModuleAuthorization instanceAuthorizaion)
|
192
|
+
{
|
193
|
+
return _instanceAuthorization;
|
194
|
+
}
|
195
|
+
|
196
|
+
|
197
|
+
function _createRoles(IAuthorization authorization)
|
198
|
+
internal
|
199
|
+
{
|
200
|
+
RoleId[] memory roles = authorization.getRoles();
|
201
|
+
RoleId roleId;
|
202
|
+
RoleInfo memory roleInfo;
|
203
|
+
|
204
|
+
for(uint256 i = 0; i < roles.length; i++) {
|
205
|
+
roleId = roles[i];
|
206
|
+
_createRole(
|
207
|
+
roleId,
|
208
|
+
authorization.getRoleInfo(roleId));
|
209
|
+
}
|
210
|
+
}
|
211
|
+
|
212
|
+
|
213
|
+
function _createTargetAuthorizations(IAuthorization authorization)
|
214
|
+
internal
|
215
|
+
{
|
216
|
+
Str[] memory targets = authorization.getTargets();
|
217
|
+
Str target;
|
218
|
+
|
219
|
+
for(uint256 i = 0; i < targets.length; i++) {
|
220
|
+
target = targets[i];
|
221
|
+
RoleId[] memory authorizedRoles = authorization.getAuthorizedRoles(target);
|
222
|
+
RoleId authorizedRole;
|
223
|
+
|
224
|
+
for(uint256 j = 0; j < authorizedRoles.length; j++) {
|
225
|
+
authorizedRole = authorizedRoles[j];
|
226
|
+
|
227
|
+
_authorizeTargetFunctions(
|
228
|
+
getTargetForName(target),
|
229
|
+
authorizedRole,
|
230
|
+
authorization.getAuthorizedFunctions(
|
231
|
+
target,
|
232
|
+
authorizedRole));
|
233
|
+
}
|
234
|
+
}
|
235
|
+
}
|
236
|
+
|
237
|
+
function _checkAndCreateTargetWithRole(
|
238
|
+
address target,
|
239
|
+
string memory targetName
|
240
|
+
)
|
241
|
+
internal
|
242
|
+
{
|
243
|
+
// check that target name is defined in authorization specification
|
244
|
+
Str name = StrLib.toStr(targetName);
|
245
|
+
if (!_instanceAuthorization.targetExists(name)) {
|
246
|
+
revert ErrorInstanceAdminExpectedTargetMissing(targetName);
|
247
|
+
}
|
248
|
+
|
249
|
+
// create named target
|
250
|
+
_createTarget(
|
251
|
+
target,
|
252
|
+
targetName,
|
253
|
+
false, // check authority TODO check normal targets, don't check service targets (they share authority with registry admin)
|
254
|
+
false);
|
255
|
+
|
256
|
+
// assign target role if defined
|
257
|
+
RoleId targetRoleId = _instanceAuthorization.getTargetRole(name);
|
258
|
+
if (targetRoleId != RoleIdLib.zero()) {
|
259
|
+
_grantRoleToAccount(targetRoleId, target);
|
260
|
+
}
|
261
|
+
}
|
262
|
+
|
263
|
+
function _createModuleTargetsWithRoles()
|
264
|
+
internal
|
265
|
+
{
|
266
|
+
// create module targets
|
267
|
+
_checkAndCreateTargetWithRole(address(_instance), INSTANCE_TARGET_NAME);
|
268
|
+
_checkAndCreateTargetWithRole(address(_instance.getInstanceStore()), INSTANCE_STORE_TARGET_NAME);
|
269
|
+
_checkAndCreateTargetWithRole(address(_instance.getInstanceAdmin()), INSTANCE_ADMIN_TARGET_NAME);
|
270
|
+
_checkAndCreateTargetWithRole(address(_instance.getBundleSet()), BUNDLE_SET_TARGET_NAME);
|
271
|
+
|
272
|
+
// create targets for services that need to access the module targets
|
273
|
+
ObjectType[] memory serviceDomains = _instanceAuthorization.getServiceDomains();
|
274
|
+
VersionPart release = _instanceAuthorization.getRelease();
|
275
|
+
ObjectType serviceDomain;
|
276
|
+
|
277
|
+
for (uint256 i = 0; i < serviceDomains.length; i++) {
|
278
|
+
serviceDomain = serviceDomains[i];
|
279
|
+
|
280
|
+
_checkAndCreateTargetWithRole(
|
281
|
+
_registry.getServiceAddress(serviceDomain, release),
|
282
|
+
_instanceAuthorization.getServiceTarget(serviceDomain).toString());
|
283
|
+
}
|
284
|
+
}
|
285
|
+
}
|
@@ -0,0 +1,204 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {
|
5
|
+
PRODUCT, ORACLE, POOL, INSTANCE, COMPONENT, DISTRIBUTION, APPLICATION, POLICY, CLAIM, BUNDLE
|
6
|
+
} from "../../contracts/type/ObjectType.sol";
|
7
|
+
|
8
|
+
import {
|
9
|
+
DISTRIBUTION_OWNER_ROLE, ORACLE_OWNER_ROLE, POOL_OWNER_ROLE, PRODUCT_OWNER_ROLE
|
10
|
+
} from "../../contracts/type/RoleId.sol";
|
11
|
+
|
12
|
+
import {BundleSet} from "../instance/BundleSet.sol";
|
13
|
+
import {IAccess} from "../authorization/IAccess.sol";
|
14
|
+
import {Instance} from "../instance/Instance.sol";
|
15
|
+
import {InstanceAdmin} from "../instance/InstanceAdmin.sol";
|
16
|
+
import {InstanceStore} from "../instance/InstanceStore.sol";
|
17
|
+
import {ModuleAuthorization} from "../authorization/ModuleAuthorization.sol";
|
18
|
+
|
19
|
+
|
20
|
+
contract InstanceAuthorizationV3
|
21
|
+
is ModuleAuthorization
|
22
|
+
{
|
23
|
+
|
24
|
+
string public constant INSTANCE_TARGET_NAME = "Instance";
|
25
|
+
string public constant INSTANCE_STORE_TARGET_NAME = "InstanceStore";
|
26
|
+
string public constant INSTANCE_ADMIN_TARGET_NAME = "InstanceAdmin";
|
27
|
+
string public constant BUNDLE_SET_TARGET_NAME = "BundleSet";
|
28
|
+
|
29
|
+
string public constant INSTANCE_ROLE_NAME = "InstanceRole";
|
30
|
+
string public constant DISTRIBUTION_OWNER_ROLE_NAME = "DistributionOwnerRole";
|
31
|
+
string public constant ORACLE_OWNER_ROLE_NAME = "OracleOwnerRole";
|
32
|
+
string public constant POOL_OWNER_ROLE_NAME = "PoolOwnerRole";
|
33
|
+
string public constant PRODUCT_OWNER_ROLE_NAME = "ProductOwnerRole";
|
34
|
+
|
35
|
+
constructor() ModuleAuthorization(INSTANCE_TARGET_NAME) {}
|
36
|
+
|
37
|
+
|
38
|
+
function _setupRoles()
|
39
|
+
internal
|
40
|
+
override
|
41
|
+
{
|
42
|
+
_addGifRole(DISTRIBUTION_OWNER_ROLE(), DISTRIBUTION_OWNER_ROLE_NAME);
|
43
|
+
_addGifRole(ORACLE_OWNER_ROLE(), ORACLE_OWNER_ROLE_NAME);
|
44
|
+
_addGifRole(POOL_OWNER_ROLE(), POOL_OWNER_ROLE_NAME);
|
45
|
+
_addGifRole(PRODUCT_OWNER_ROLE(), PRODUCT_OWNER_ROLE_NAME);
|
46
|
+
}
|
47
|
+
|
48
|
+
|
49
|
+
function _setupTargets()
|
50
|
+
internal
|
51
|
+
override
|
52
|
+
{
|
53
|
+
// instance target
|
54
|
+
_addTargetWithRole(
|
55
|
+
INSTANCE_TARGET_NAME,
|
56
|
+
_getTargetRoleId(INSTANCE()),
|
57
|
+
INSTANCE_ROLE_NAME);
|
58
|
+
|
59
|
+
// instance supporting targets
|
60
|
+
_addTarget(INSTANCE_STORE_TARGET_NAME);
|
61
|
+
_addTarget(INSTANCE_ADMIN_TARGET_NAME);
|
62
|
+
_addTarget(BUNDLE_SET_TARGET_NAME);
|
63
|
+
|
64
|
+
// service targets relevant to instance
|
65
|
+
_addServiceTargetWithRole(INSTANCE());
|
66
|
+
_addServiceTargetWithRole(COMPONENT());
|
67
|
+
_addServiceTargetWithRole(DISTRIBUTION());
|
68
|
+
_addServiceTargetWithRole(ORACLE());
|
69
|
+
_addServiceTargetWithRole(POOL());
|
70
|
+
_addServiceTargetWithRole(BUNDLE());
|
71
|
+
_addServiceTargetWithRole(PRODUCT());
|
72
|
+
_addServiceTargetWithRole(APPLICATION());
|
73
|
+
_addServiceTargetWithRole(POLICY());
|
74
|
+
_addServiceTargetWithRole(CLAIM());
|
75
|
+
}
|
76
|
+
|
77
|
+
|
78
|
+
function _setupTargetAuthorizations()
|
79
|
+
internal
|
80
|
+
override
|
81
|
+
{
|
82
|
+
_setupInstanceAuthorization();
|
83
|
+
_setupInstanceAdminAuthorization();
|
84
|
+
_setupInstanceStoreAuthorization();
|
85
|
+
_setupBundleSetAuthorization();
|
86
|
+
}
|
87
|
+
|
88
|
+
|
89
|
+
function _setupBundleSetAuthorization()
|
90
|
+
internal
|
91
|
+
{
|
92
|
+
IAccess.FunctionInfo[] storage functions;
|
93
|
+
|
94
|
+
// authorize bundle service role
|
95
|
+
functions = _authorizeForTarget(BUNDLE_SET_TARGET_NAME, getServiceRole(BUNDLE()));
|
96
|
+
_authorize(functions, BundleSet.linkPolicy.selector, "linkPolicy");
|
97
|
+
_authorize(functions, BundleSet.unlinkPolicy.selector, "unlinkPolicy");
|
98
|
+
_authorize(functions, BundleSet.add.selector, "add");
|
99
|
+
_authorize(functions, BundleSet.lock.selector, "lock");
|
100
|
+
_authorize(functions, BundleSet.unlock.selector, "unlock");
|
101
|
+
}
|
102
|
+
|
103
|
+
|
104
|
+
function _setupInstanceAuthorization()
|
105
|
+
internal
|
106
|
+
{
|
107
|
+
IAccess.FunctionInfo[] storage functions;
|
108
|
+
|
109
|
+
// authorize instance service role
|
110
|
+
functions = _authorizeForTarget(INSTANCE_TARGET_NAME, getServiceRole(INSTANCE()));
|
111
|
+
_authorize(functions, Instance.setInstanceReader.selector, "setInstanceReader");
|
112
|
+
}
|
113
|
+
|
114
|
+
|
115
|
+
function _setupInstanceAdminAuthorization()
|
116
|
+
internal
|
117
|
+
{
|
118
|
+
IAccess.FunctionInfo[] storage functions;
|
119
|
+
|
120
|
+
// authorize instance role
|
121
|
+
functions = _authorizeForTarget(INSTANCE_ADMIN_TARGET_NAME, _getTargetRoleId(INSTANCE()));
|
122
|
+
_authorize(functions, InstanceAdmin.grantRole.selector, "grantRole");
|
123
|
+
|
124
|
+
// authorize instance service role
|
125
|
+
// functions = _authorizeForTarget(INSTANCE_ADMIN_TARGET_NAME, getServiceRole(INSTANCE()));
|
126
|
+
}
|
127
|
+
|
128
|
+
|
129
|
+
function _setupInstanceStoreAuthorization()
|
130
|
+
internal
|
131
|
+
{
|
132
|
+
IAccess.FunctionInfo[] storage functions;
|
133
|
+
|
134
|
+
// authorize component service role
|
135
|
+
functions = _authorizeForTarget(INSTANCE_STORE_TARGET_NAME, getServiceRole(COMPONENT()));
|
136
|
+
_authorize(functions, InstanceStore.createComponent.selector, "createComponent");
|
137
|
+
_authorize(functions, InstanceStore.updateComponent.selector, "updateComponent");
|
138
|
+
_authorize(functions, InstanceStore.createPool.selector, "createPool");
|
139
|
+
_authorize(functions, InstanceStore.createProduct.selector, "createProduct");
|
140
|
+
_authorize(functions, InstanceStore.updateProduct.selector, "updateProduct");
|
141
|
+
_authorize(functions, InstanceStore.increaseBalance.selector, "increaseBalance");
|
142
|
+
_authorize(functions, InstanceStore.decreaseBalance.selector, "decreaseBalance");
|
143
|
+
_authorize(functions, InstanceStore.increaseFees.selector, "increaseFees");
|
144
|
+
_authorize(functions, InstanceStore.decreaseFees.selector, "decreaseFees");
|
145
|
+
|
146
|
+
// authorize distribution service role
|
147
|
+
functions = _authorizeForTarget(INSTANCE_STORE_TARGET_NAME, getServiceRole(DISTRIBUTION()));
|
148
|
+
_authorize(functions, InstanceStore.createDistributorType.selector, "createDistributorType");
|
149
|
+
_authorize(functions, InstanceStore.updateDistributorType.selector, "updateDistributorType");
|
150
|
+
_authorize(functions, InstanceStore.updateDistributorTypeState.selector, "updateDistributorTypeState");
|
151
|
+
_authorize(functions, InstanceStore.createDistributor.selector, "createDistributor");
|
152
|
+
_authorize(functions, InstanceStore.updateDistributor.selector, "updateDistributor");
|
153
|
+
_authorize(functions, InstanceStore.updateDistributorState.selector, "updateDistributorState");
|
154
|
+
_authorize(functions, InstanceStore.createReferral.selector, "createReferral");
|
155
|
+
_authorize(functions, InstanceStore.updateReferral.selector, "updateReferral");
|
156
|
+
_authorize(functions, InstanceStore.updateReferralState.selector, "updateReferralState");
|
157
|
+
|
158
|
+
// authorize oracle service role
|
159
|
+
functions = _authorizeForTarget(INSTANCE_STORE_TARGET_NAME, getServiceRole(ORACLE()));
|
160
|
+
_authorize(functions, InstanceStore.createRequest.selector, "createRequest");
|
161
|
+
_authorize(functions, InstanceStore.updateRequest.selector, "updateRequest");
|
162
|
+
_authorize(functions, InstanceStore.updateRequestState.selector, "updateRequestState");
|
163
|
+
|
164
|
+
// authorize pool service role
|
165
|
+
functions = _authorizeForTarget(INSTANCE_STORE_TARGET_NAME, getServiceRole(POOL()));
|
166
|
+
_authorize(functions, InstanceStore.updatePool.selector, "updatePool");
|
167
|
+
|
168
|
+
// authorize bundle service role
|
169
|
+
functions = _authorizeForTarget(INSTANCE_STORE_TARGET_NAME, getServiceRole(BUNDLE()));
|
170
|
+
_authorize(functions, InstanceStore.createBundle.selector, "createBundle");
|
171
|
+
_authorize(functions, InstanceStore.updateBundle.selector, "updateBundle");
|
172
|
+
_authorize(functions, InstanceStore.updateBundleState.selector, "updateBundleState");
|
173
|
+
_authorize(functions, InstanceStore.increaseLocked.selector, "increaseLocked");
|
174
|
+
_authorize(functions, InstanceStore.decreaseLocked.selector, "decreaseLocked");
|
175
|
+
|
176
|
+
// authorize product service role
|
177
|
+
functions = _authorizeForTarget(INSTANCE_STORE_TARGET_NAME, getServiceRole(PRODUCT()));
|
178
|
+
_authorize(functions, InstanceStore.createRisk.selector, "createRisk");
|
179
|
+
_authorize(functions, InstanceStore.updateRisk.selector, "updateRisk");
|
180
|
+
_authorize(functions, InstanceStore.updateRiskState.selector, "updateRiskState");
|
181
|
+
|
182
|
+
// authorize application service role
|
183
|
+
functions = _authorizeForTarget(INSTANCE_STORE_TARGET_NAME, getServiceRole(APPLICATION()));
|
184
|
+
_authorize(functions, InstanceStore.createApplication.selector, "createApplication");
|
185
|
+
_authorize(functions, InstanceStore.updateApplication.selector, "updateApplication");
|
186
|
+
_authorize(functions, InstanceStore.updateApplicationState.selector, "updateApplicationState");
|
187
|
+
|
188
|
+
// authorize policy service role
|
189
|
+
functions = _authorizeForTarget(INSTANCE_STORE_TARGET_NAME, getServiceRole(POLICY()));
|
190
|
+
_authorize(functions, InstanceStore.updatePolicy.selector, "updatePolicy");
|
191
|
+
_authorize(functions, InstanceStore.updatePolicyState.selector, "updatePolicyState");
|
192
|
+
_authorize(functions, InstanceStore.createPremium.selector, "createPremium");
|
193
|
+
_authorize(functions, InstanceStore.updatePremiumState.selector, "updatePremiumState");
|
194
|
+
|
195
|
+
// authorize claim service role
|
196
|
+
functions = _authorizeForTarget(INSTANCE_STORE_TARGET_NAME, getServiceRole(CLAIM()));
|
197
|
+
_authorize(functions, InstanceStore.updatePolicyClaims.selector, "updatePolicyClaims");
|
198
|
+
_authorize(functions, InstanceStore.createClaim.selector, "createClaim");
|
199
|
+
_authorize(functions, InstanceStore.updateClaim.selector, "updateClaim");
|
200
|
+
_authorize(functions, InstanceStore.createPayout.selector, "createPayout");
|
201
|
+
_authorize(functions, InstanceStore.updatePayout.selector, "updatePayout");
|
202
|
+
}
|
203
|
+
}
|
204
|
+
|
@@ -1,29 +1,26 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
|
-
|
6
4
|
import {Amount} from "../type/Amount.sol";
|
7
5
|
import {ClaimId} from "../type/ClaimId.sol";
|
8
6
|
import {DistributorType} from "../type/DistributorType.sol";
|
9
|
-
import {Fee, FeeLib} from "../type/Fee.sol";
|
10
7
|
import {Key32} from "../type/Key32.sol";
|
11
8
|
import {NftId} from "../type/NftId.sol";
|
12
|
-
import {
|
9
|
+
import {COMPONENT, DISTRIBUTOR, DISTRIBUTION, PREMIUM, PRODUCT, POLICY, POOL, BUNDLE} from "../type/ObjectType.sol";
|
13
10
|
import {PayoutId} from "../type/PayoutId.sol";
|
14
11
|
import {ReferralId, ReferralStatus, ReferralLib, REFERRAL_OK, REFERRAL_ERROR_UNKNOWN, REFERRAL_ERROR_EXPIRED, REFERRAL_ERROR_EXHAUSTED} from "../type/Referral.sol";
|
15
|
-
import {
|
12
|
+
import {RequestId} from "../type/RequestId.sol";
|
16
13
|
import {RiskId} from "../type/RiskId.sol";
|
17
|
-
import {
|
18
|
-
import {Version} from "../type/Version.sol";
|
14
|
+
import {RoleId} from "../type/RoleId.sol";
|
19
15
|
import {StateId} from "../type/StateId.sol";
|
16
|
+
import {UFixed, UFixedLib} from "../type/UFixed.sol";
|
20
17
|
|
21
|
-
import {IRegistry} from "../registry/IRegistry.sol";
|
22
18
|
import {IBundle} from "../instance/module/IBundle.sol";
|
23
19
|
import {IComponents} from "../instance/module/IComponents.sol";
|
24
20
|
import {IDistribution} from "../instance/module/IDistribution.sol";
|
25
21
|
import {IInstance} from "./IInstance.sol";
|
26
22
|
import {IKeyValueStore} from "../shared/IKeyValueStore.sol";
|
23
|
+
import {IOracle} from "../oracle/IOracle.sol";
|
27
24
|
import {IPolicy} from "../instance/module/IPolicy.sol";
|
28
25
|
import {IRisk} from "../instance/module/IRisk.sol";
|
29
26
|
import {TimestampLib} from "../type/Timestamp.sol";
|
@@ -36,24 +33,29 @@ contract InstanceReader {
|
|
36
33
|
error ErrorInstanceReaderAlreadyInitialized();
|
37
34
|
error ErrorInstanceReaderInstanceAddressZero();
|
38
35
|
|
39
|
-
bool private _initialized;
|
36
|
+
bool private _initialized = false;
|
40
37
|
|
41
38
|
IInstance internal _instance;
|
42
39
|
InstanceStore internal _store;
|
43
40
|
|
44
|
-
|
41
|
+
/// @dev This initializer needs to be called from the instance itself.
|
42
|
+
function initialize() public {
|
45
43
|
if(_initialized) {
|
46
44
|
revert ErrorInstanceReaderAlreadyInitialized();
|
47
45
|
}
|
48
46
|
|
49
|
-
|
50
|
-
|
51
|
-
}
|
47
|
+
initializeWithInstance(msg.sender);
|
48
|
+
}
|
52
49
|
|
53
|
-
|
54
|
-
|
50
|
+
/// @dev This initializer needs to be called from the instance itself.
|
51
|
+
function initializeWithInstance(address instanceAddress) public {
|
52
|
+
if(_initialized) {
|
53
|
+
revert ErrorInstanceReaderAlreadyInitialized();
|
54
|
+
}
|
55
55
|
|
56
56
|
_initialized = true;
|
57
|
+
_instance = IInstance(instanceAddress);
|
58
|
+
_store = _instance.getInstanceStore();
|
57
59
|
}
|
58
60
|
|
59
61
|
|
@@ -78,6 +80,33 @@ contract InstanceReader {
|
|
78
80
|
return _store.getState(toPolicyKey(policyNftId));
|
79
81
|
}
|
80
82
|
|
83
|
+
function getPremiumInfo(NftId policyNftId)
|
84
|
+
public
|
85
|
+
view
|
86
|
+
returns (IPolicy.PremiumInfo memory info)
|
87
|
+
{
|
88
|
+
bytes memory data = _store.getData(toPremiumKey(policyNftId));
|
89
|
+
if (data.length > 0) {
|
90
|
+
return abi.decode(data, (IPolicy.PremiumInfo));
|
91
|
+
}
|
92
|
+
}
|
93
|
+
|
94
|
+
function getPremiumInfoState(NftId policyNftId)
|
95
|
+
public
|
96
|
+
view
|
97
|
+
returns (StateId state)
|
98
|
+
{
|
99
|
+
return _store.getState(toPremiumKey(policyNftId));
|
100
|
+
}
|
101
|
+
|
102
|
+
function getBundleState(NftId bundleNftId)
|
103
|
+
public
|
104
|
+
view
|
105
|
+
returns (StateId state)
|
106
|
+
{
|
107
|
+
return _store.getState(toBundleKey(bundleNftId));
|
108
|
+
}
|
109
|
+
|
81
110
|
/// @dev returns true iff policy may be closed
|
82
111
|
/// a policy can be closed all conditions below are met
|
83
112
|
/// - policy exists
|
@@ -202,15 +231,15 @@ contract InstanceReader {
|
|
202
231
|
}
|
203
232
|
}
|
204
233
|
|
205
|
-
function getBalanceAmount(NftId targetNftId) external returns (Amount) {
|
234
|
+
function getBalanceAmount(NftId targetNftId) external view returns (Amount) {
|
206
235
|
return _store.getBalanceAmount(targetNftId);
|
207
236
|
}
|
208
237
|
|
209
|
-
function getLockedAmount(NftId targetNftId) external returns (Amount) {
|
238
|
+
function getLockedAmount(NftId targetNftId) external view returns (Amount) {
|
210
239
|
return _store.getLockedAmount(targetNftId);
|
211
240
|
}
|
212
241
|
|
213
|
-
function getFeeAmount(NftId targetNftId) external returns (Amount) {
|
242
|
+
function getFeeAmount(NftId targetNftId) external view returns (Amount) {
|
214
243
|
return _store.getFeeAmount(targetNftId);
|
215
244
|
}
|
216
245
|
|
@@ -258,6 +287,16 @@ contract InstanceReader {
|
|
258
287
|
}
|
259
288
|
}
|
260
289
|
|
290
|
+
function getRequestInfo(RequestId requestId)
|
291
|
+
public
|
292
|
+
view
|
293
|
+
returns (IOracle.RequestInfo memory requestInfo)
|
294
|
+
{
|
295
|
+
bytes memory data = _store.getData(requestId.toKey32());
|
296
|
+
if (data.length > 0) {
|
297
|
+
return abi.decode(data, (IOracle.RequestInfo));
|
298
|
+
}
|
299
|
+
}
|
261
300
|
|
262
301
|
function getMetadata(Key32 key)
|
263
302
|
public
|
@@ -267,6 +306,14 @@ contract InstanceReader {
|
|
267
306
|
return _store.getMetadata(key);
|
268
307
|
}
|
269
308
|
|
309
|
+
function getState(Key32 key)
|
310
|
+
public
|
311
|
+
view
|
312
|
+
returns (StateId state)
|
313
|
+
{
|
314
|
+
return _store.getMetadata(key).state;
|
315
|
+
}
|
316
|
+
|
270
317
|
|
271
318
|
function toReferralId(
|
272
319
|
NftId distributionNftId,
|
@@ -318,10 +365,27 @@ contract InstanceReader {
|
|
318
365
|
}
|
319
366
|
|
320
367
|
|
368
|
+
function hasRole(address account, RoleId roleId) public view returns (bool isMember) {
|
369
|
+
return _instance.getInstanceAdmin().hasRole(account, roleId);
|
370
|
+
}
|
371
|
+
|
372
|
+
|
373
|
+
function hasAdminRole(address account, RoleId roleId) public view returns (bool isMember) {
|
374
|
+
return _instance.getInstanceAdmin().hasAdminRole(account, roleId);
|
375
|
+
}
|
376
|
+
|
377
|
+
|
378
|
+
function isTargetLocked(address target) public view returns (bool) {
|
379
|
+
return _instance.getInstanceAdmin().isTargetLocked(target);
|
380
|
+
}
|
381
|
+
|
321
382
|
function toPolicyKey(NftId policyNftId) public pure returns (Key32) {
|
322
383
|
return policyNftId.toKey32(POLICY());
|
323
384
|
}
|
324
385
|
|
386
|
+
function toPremiumKey(NftId policyNftId) public pure returns (Key32) {
|
387
|
+
return policyNftId.toKey32(PREMIUM());
|
388
|
+
}
|
325
389
|
|
326
390
|
function toDistributorKey(NftId distributorNftId) public pure returns (Key32) {
|
327
391
|
return distributorNftId.toKey32(DISTRIBUTOR());
|