@etherisc/gif-next 0.0.2-93a7619-595 → 0.0.2-93ee1cf-782
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 +27 -6
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +96 -37
- package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.json +24 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +67 -11
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +60 -13
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +40 -3
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +19 -0
- package/artifacts/contracts/authorization/ReleaseAccessManager.sol/ReleaseAccessManager.dbg.json +4 -0
- package/artifacts/contracts/authorization/ReleaseAccessManager.sol/ReleaseAccessManager.json +1196 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +68 -5
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +143 -182
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +77 -17
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +83 -98
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +175 -86
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +104 -60
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +73 -83
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +52 -0
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +113 -196
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +114 -22
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +215 -235
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +81 -25
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +155 -157
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +114 -129
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +230 -190
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +508 -228
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +147 -42
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +98 -30
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +53 -88
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +131 -42
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +168 -125
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +58 -85
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +327 -84
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +113 -135
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +72 -40
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +172 -111
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +810 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +2 -2
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +46 -5
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +2 -2
- 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 +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +102 -141
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +77 -17
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +68 -78
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +43 -9
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +78 -93
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +142 -79
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +92 -36
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +78 -121
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +114 -22
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +143 -214
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +84 -84
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +48 -57
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +68 -117
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +106 -88
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +78 -132
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +195 -188
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +87 -51
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +114 -45
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +68 -36
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +123 -94
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +77 -17
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +175 -88
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +97 -61
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +63 -7
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +66 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +67 -19
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +80 -51
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +109 -75
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.json +29 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +174 -129
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +96 -56
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +165 -107
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +85 -45
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +119 -90
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +76 -26
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +66 -30
- 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 +72 -15
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +114 -35
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -18
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +116 -51
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +206 -165
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +161 -61
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +65 -29
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +47 -6
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +123 -225
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +66 -8
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +2 -2
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +76 -87
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +442 -180
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +115 -63
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +42 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +402 -6
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.json +24 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.json +30 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +66 -72
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +388 -19
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +68 -78
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +36 -0
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +36 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +16 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +29 -0
- 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 +29 -0
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +78 -93
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +42 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +42 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +2 -2
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +18 -2
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +2 -2
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +66 -8
- 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 +42 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +388 -35
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +395 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +88 -24
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +84 -108
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +29 -21
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +2 -2
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +154 -187
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +46 -5
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +81 -51
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +2 -2
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +82 -53
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +69 -33
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +144 -103
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +2 -2
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- 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/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +4 -0
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +23 -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 +2 -2
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +2 -2
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +2 -2
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +2 -2
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +43 -5
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +2 -2
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +15 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- 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/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +44 -12
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
- package/contracts/authorization/AccessAdmin.sol +86 -62
- package/contracts/authorization/Authorization.sol +106 -38
- package/contracts/authorization/IAccess.sol +1 -0
- package/contracts/authorization/IAccessAdmin.sol +4 -2
- package/contracts/authorization/IAuthorization.sol +13 -7
- package/contracts/authorization/IServiceAuthorization.sol +3 -1
- package/contracts/authorization/ReleaseAccessManager.sol +38 -0
- package/contracts/authorization/ServiceAuthorization.sol +26 -10
- package/contracts/distribution/BasicDistribution.sol +4 -3
- package/contracts/distribution/BasicDistributionAuthorization.sol +1 -1
- package/contracts/distribution/Distribution.sol +11 -22
- package/contracts/distribution/DistributionService.sol +69 -51
- package/contracts/distribution/IDistributionComponent.sol +1 -1
- package/contracts/distribution/IDistributionService.sol +5 -6
- package/contracts/examples/fire/FirePool.sol +19 -8
- package/contracts/examples/fire/FireProduct.sol +33 -13
- package/contracts/examples/fire/FireProductAuthorization.sol +1 -2
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +12 -4
- package/contracts/examples/unpermissioned/SimpleOracle.sol +4 -4
- package/contracts/examples/unpermissioned/SimplePool.sol +38 -6
- package/contracts/examples/unpermissioned/SimpleProduct.sol +17 -23
- package/contracts/instance/BundleSet.sol +38 -34
- package/contracts/instance/IInstance.sol +10 -1
- package/contracts/instance/IInstanceService.sol +7 -25
- package/contracts/instance/Instance.sol +34 -22
- package/contracts/instance/InstanceAdmin.sol +20 -30
- package/contracts/instance/InstanceAuthorizationV3.sol +38 -25
- package/contracts/instance/InstanceReader.sol +85 -1
- package/contracts/instance/InstanceService.sol +46 -87
- package/contracts/instance/RiskSet.sol +119 -0
- package/contracts/instance/base/ObjectLifecycle.sol +1 -1
- package/contracts/instance/base/ObjectSet.sol +24 -25
- package/contracts/instance/module/IComponents.sol +7 -5
- package/contracts/instance/module/IPolicy.sol +2 -1
- package/contracts/instance/module/IRisk.sol +1 -0
- package/contracts/oracle/BasicOracle.sol +0 -1
- package/contracts/oracle/IOracleService.sol +2 -1
- package/contracts/oracle/Oracle.sol +4 -15
- package/contracts/oracle/OracleService.sol +103 -75
- package/contracts/pool/BasicPool.sol +33 -24
- package/contracts/pool/BasicPoolAuthorization.sol +12 -2
- package/contracts/pool/BundleService.sol +60 -98
- package/contracts/pool/IBundleService.sol +2 -23
- package/contracts/pool/IPoolComponent.sol +1 -7
- package/contracts/pool/IPoolService.sol +12 -30
- package/contracts/pool/Pool.sol +118 -126
- package/contracts/pool/PoolService.sol +191 -142
- package/contracts/product/ApplicationService.sol +21 -13
- package/contracts/product/BasicProduct.sol +8 -12
- package/contracts/product/BasicProductAuthorization.sol +0 -1
- package/contracts/product/ClaimService.sol +113 -51
- package/contracts/product/IApplicationService.sol +5 -2
- package/contracts/product/IClaimService.sol +7 -0
- package/contracts/product/IPolicyService.sol +17 -7
- package/contracts/product/IPricingService.sol +9 -9
- package/contracts/product/IProductComponent.sol +6 -0
- package/contracts/product/PolicyService.sol +241 -194
- package/contracts/product/PricingService.sol +8 -8
- package/contracts/product/Product.sol +56 -61
- package/contracts/product/RiskService.sol +14 -3
- package/contracts/registry/ChainNft.sol +6 -9
- package/contracts/registry/IRegistry.sol +6 -3
- package/contracts/registry/IRegistryService.sol +6 -4
- package/contracts/registry/ITransferInterceptor.sol +1 -2
- package/contracts/registry/Registry.sol +22 -4
- package/contracts/registry/RegistryAdmin.sol +21 -34
- package/contracts/registry/RegistryService.sol +37 -55
- package/contracts/registry/ReleaseLifecycle.sol +6 -3
- package/contracts/registry/ReleaseRegistry.sol +202 -208
- package/contracts/registry/ServiceAuthorizationV3.sol +17 -40
- package/contracts/shared/Component.sol +47 -106
- package/contracts/shared/ComponentService.sol +322 -157
- package/contracts/shared/ComponentVerifyingService.sol +27 -15
- package/contracts/shared/ContractLib.sol +196 -10
- package/contracts/shared/IComponent.sol +10 -16
- package/contracts/shared/IComponentService.sol +38 -16
- package/contracts/shared/IInstanceLinkedComponent.sol +3 -11
- package/contracts/shared/ILifecycle.sol +3 -1
- package/contracts/shared/INftOwnable.sol +2 -0
- package/contracts/shared/IRegisterable.sol +11 -0
- package/contracts/shared/InstanceLinkedComponent.sol +66 -32
- package/contracts/shared/KeyValueStore.sol +1 -1
- package/contracts/shared/Lifecycle.sol +15 -4
- package/contracts/shared/NftOwnable.sol +23 -3
- package/contracts/shared/Registerable.sol +15 -7
- package/contracts/shared/RegistryLinked.sol +6 -12
- package/contracts/shared/Service.sol +4 -7
- package/contracts/shared/TokenHandler.sol +316 -66
- package/contracts/shared/TokenHandlerDeployerLib.sol +10 -2
- package/contracts/staking/IStaking.sol +9 -4
- package/contracts/staking/IStakingService.sol +0 -3
- package/contracts/staking/Staking.sol +31 -24
- package/contracts/staking/StakingService.sol +56 -23
- package/contracts/type/Key32.sol +2 -2
- package/contracts/type/Key32Set.sol +62 -0
- package/contracts/type/NftId.sol +6 -0
- package/contracts/type/ObjectType.sol +2 -0
- package/contracts/type/RiskId.sol +18 -6
- package/contracts/type/RoleId.sol +0 -12
- package/contracts/type/StateId.sol +14 -1
- package/contracts/upgradeability/ProxyManager.sol +2 -1
- package/package.json +3 -3
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +0 -4
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.json +0 -290
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +0 -4
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +0 -390
- package/contracts/authorization/IModuleAuthorization.sol +0 -21
- package/contracts/authorization/ModuleAuthorization.sol +0 -78
@@ -13,6 +13,9 @@ import {Selector, SelectorLib, SelectorSetLib} from "../type/Selector.sol";
|
|
13
13
|
import {Str, StrLib} from "../type/String.sol";
|
14
14
|
import {TimestampLib} from "../type/Timestamp.sol";
|
15
15
|
|
16
|
+
interface IAccessManagedChecker {
|
17
|
+
function authority() external view returns (address);
|
18
|
+
}
|
16
19
|
|
17
20
|
/**
|
18
21
|
* @dev A generic access amin contract that implements role based access control based on OpenZeppelin's AccessManager contract.
|
@@ -80,9 +83,7 @@ contract AccessAdmin is
|
|
80
83
|
}
|
81
84
|
|
82
85
|
modifier onlyRoleAdmin(RoleId roleId) {
|
83
|
-
|
84
|
-
revert ErrorRoleUnknown(roleId);
|
85
|
-
}
|
86
|
+
_checkRoleExists(roleId, false);
|
86
87
|
|
87
88
|
if (!hasAdminRole(msg.sender, roleId)) {
|
88
89
|
revert ErrorNotAdminOfRole(_roleInfo[roleId].adminRoleId);
|
@@ -97,8 +98,8 @@ contract AccessAdmin is
|
|
97
98
|
_;
|
98
99
|
}
|
99
100
|
|
100
|
-
modifier onlyExistingRole(RoleId roleId) {
|
101
|
-
|
101
|
+
modifier onlyExistingRole(RoleId roleId, bool onlyActiveRole) {
|
102
|
+
_checkRoleExists(roleId, onlyActiveRole);
|
102
103
|
_;
|
103
104
|
}
|
104
105
|
|
@@ -219,19 +220,6 @@ contract AccessAdmin is
|
|
219
220
|
selector.toBytes4()));
|
220
221
|
}
|
221
222
|
|
222
|
-
// TODO cleanup
|
223
|
-
// function isAccessManaged(address target) public view returns (bool) {
|
224
|
-
// if (!_isContract(target)) {
|
225
|
-
// return false;
|
226
|
-
// }
|
227
|
-
|
228
|
-
// (bool success, ) = target.staticcall(
|
229
|
-
// abi.encodeWithSelector(
|
230
|
-
// AccessManagedUpgradeable.authority.selector));
|
231
|
-
|
232
|
-
// return success;
|
233
|
-
// }
|
234
|
-
|
235
223
|
function canCall(address caller, address target, Selector selector) external virtual view returns (bool can) {
|
236
224
|
(can, ) = _authority.canCall(caller, target, selector.toBytes4());
|
237
225
|
}
|
@@ -242,7 +230,8 @@ contract AccessAdmin is
|
|
242
230
|
adminRoleId: adminRoleId,
|
243
231
|
roleType: roleType,
|
244
232
|
maxMemberCount: maxMemberCount,
|
245
|
-
createdAt: TimestampLib.blockTimestamp()
|
233
|
+
createdAt: TimestampLib.blockTimestamp(),
|
234
|
+
pausedAt: TimestampLib.max()
|
246
235
|
});
|
247
236
|
}
|
248
237
|
|
@@ -373,14 +362,6 @@ contract AccessAdmin is
|
|
373
362
|
name: PUBLIC_ROLE_NAME}));
|
374
363
|
}
|
375
364
|
|
376
|
-
/// @dev check if target exists and reverts if it doesn't
|
377
|
-
function _checkTarget(address target)
|
378
|
-
internal
|
379
|
-
{
|
380
|
-
if (_targetInfo[target].createdAt.eqz()) {
|
381
|
-
revert ErrorTargetUnknown(target);
|
382
|
-
}
|
383
|
-
}
|
384
365
|
|
385
366
|
/// @dev grant the specified role access to all functions in the provided selector list
|
386
367
|
function _grantRoleAccessToFunctions(
|
@@ -398,22 +379,26 @@ contract AccessAdmin is
|
|
398
379
|
// implizit logging: rely on OpenZeppelin log TargetFunctionRoleUpdated
|
399
380
|
}
|
400
381
|
|
382
|
+
|
401
383
|
/// @dev grant the specified role to the provided account
|
402
384
|
function _grantRoleToAccount(RoleId roleId, address account)
|
403
385
|
internal
|
386
|
+
onlyExistingRole(roleId, true)
|
404
387
|
{
|
405
|
-
_checkRoleId(roleId);
|
406
|
-
|
407
388
|
// check max role members will not be exceeded
|
408
389
|
if (_roleMembers[roleId].length() >= _roleInfo[roleId].maxMemberCount) {
|
409
390
|
revert ErrorRoleMembersLimitReached(roleId, _roleInfo[roleId].maxMemberCount);
|
410
391
|
}
|
411
392
|
|
412
393
|
// check account is contract for contract role
|
413
|
-
|
414
|
-
|
394
|
+
if (
|
395
|
+
_roleInfo[roleId].roleType == RoleType.Contract &&
|
396
|
+
!ContractLib.isContract(account) // will fail in account's constructor
|
397
|
+
) {
|
398
|
+
revert ErrorRoleMemberNotContract(roleId, account);
|
415
399
|
}
|
416
400
|
|
401
|
+
// TODO check account already have roleId
|
417
402
|
_roleMembers[roleId].add(account);
|
418
403
|
_authority.grantRole(
|
419
404
|
RoleId.unwrap(roleId),
|
@@ -426,14 +411,15 @@ contract AccessAdmin is
|
|
426
411
|
/// @dev revoke the specified role from the provided account
|
427
412
|
function _revokeRoleFromAccount(RoleId roleId, address account)
|
428
413
|
internal
|
414
|
+
onlyExistingRole(roleId, false)
|
429
415
|
{
|
430
|
-
_checkRoleId(roleId);
|
431
416
|
|
432
417
|
// check role removal is permitted
|
433
418
|
if (_roleInfo[roleId].roleType == RoleType.Contract) {
|
434
|
-
revert
|
419
|
+
revert ErrorRoleMemberRemovalDisabled(roleId, account);
|
435
420
|
}
|
436
421
|
|
422
|
+
// TODO check account have roleId?
|
437
423
|
_roleMembers[roleId].remove(account);
|
438
424
|
_authority.revokeRole(
|
439
425
|
RoleId.unwrap(roleId),
|
@@ -443,21 +429,6 @@ contract AccessAdmin is
|
|
443
429
|
}
|
444
430
|
|
445
431
|
|
446
|
-
function _checkRoleId(RoleId roleId)
|
447
|
-
internal
|
448
|
-
{
|
449
|
-
if (_roleInfo[roleId].createdAt.eqz()) {
|
450
|
-
revert ErrorRoleUnknown(roleId);
|
451
|
-
}
|
452
|
-
|
453
|
-
uint64 roleIdInt = RoleId.unwrap(roleId);
|
454
|
-
if (roleIdInt == _authority.ADMIN_ROLE()
|
455
|
-
|| roleIdInt == _authority.PUBLIC_ROLE())
|
456
|
-
{
|
457
|
-
revert ErrorRoleIsLocked(roleId);
|
458
|
-
}
|
459
|
-
}
|
460
|
-
|
461
432
|
/// @dev Creates a role based on the provided parameters.
|
462
433
|
/// Checks that the provided role and role id and role name not already used.
|
463
434
|
function _createRole(
|
@@ -548,7 +519,7 @@ contract AccessAdmin is
|
|
548
519
|
}
|
549
520
|
|
550
521
|
// check target is an access managed contract
|
551
|
-
if (!
|
522
|
+
if (!_isAccessManaged(target)) {
|
552
523
|
revert ErrorTargetNotAccessManaged(target);
|
553
524
|
}
|
554
525
|
|
@@ -576,17 +547,70 @@ contract AccessAdmin is
|
|
576
547
|
emit LogTargetCreated(target, targetName);
|
577
548
|
}
|
578
549
|
|
579
|
-
|
580
|
-
|
581
|
-
|
582
|
-
|
583
|
-
|
584
|
-
|
585
|
-
|
586
|
-
|
587
|
-
|
588
|
-
|
589
|
-
|
590
|
-
|
591
|
-
|
550
|
+
|
551
|
+
function _isAccessManaged(address target)
|
552
|
+
internal
|
553
|
+
view
|
554
|
+
returns (bool)
|
555
|
+
{
|
556
|
+
if (!ContractLib.isContract(target)) {
|
557
|
+
return false;
|
558
|
+
}
|
559
|
+
|
560
|
+
(bool success, ) = target.staticcall(
|
561
|
+
abi.encodeWithSelector(
|
562
|
+
IAccessManagedChecker.authority.selector));
|
563
|
+
|
564
|
+
return success;
|
565
|
+
}
|
566
|
+
|
567
|
+
|
568
|
+
function _setTargetClosed(address target, bool locked)
|
569
|
+
internal
|
570
|
+
{
|
571
|
+
_checkTarget(target);
|
572
|
+
|
573
|
+
// target locked/unlocked already
|
574
|
+
if(_authority.isTargetClosed(target) == locked) {
|
575
|
+
revert ErrorTargetAlreadyLocked(target, locked);
|
576
|
+
}
|
577
|
+
|
578
|
+
_authority.setTargetClosed(target, locked);
|
579
|
+
}
|
580
|
+
|
581
|
+
|
582
|
+
function _checkRoleExists(
|
583
|
+
RoleId roleId,
|
584
|
+
bool onlyActiveRole
|
585
|
+
)
|
586
|
+
internal
|
587
|
+
view
|
588
|
+
{
|
589
|
+
if (!roleExists(roleId)) {
|
590
|
+
revert ErrorRoleUnknown(roleId);
|
591
|
+
}
|
592
|
+
|
593
|
+
uint64 roleIdInt = RoleId.unwrap(roleId);
|
594
|
+
if (roleIdInt == _authority.ADMIN_ROLE()
|
595
|
+
|| roleIdInt == _authority.PUBLIC_ROLE())
|
596
|
+
{
|
597
|
+
revert ErrorRoleIsLocked(roleId);
|
598
|
+
}
|
599
|
+
|
600
|
+
// check if role is disabled
|
601
|
+
if (onlyActiveRole && _roleInfo[roleId].pausedAt <= TimestampLib.blockTimestamp()) {
|
602
|
+
revert ErrorRoleIsPaused(roleId);
|
603
|
+
}
|
604
|
+
}
|
605
|
+
|
606
|
+
|
607
|
+
/// @dev check if target exists and reverts if it doesn't
|
608
|
+
function _checkTarget(address target)
|
609
|
+
internal
|
610
|
+
view
|
611
|
+
{
|
612
|
+
if (!targetExists(target)) {
|
613
|
+
revert ErrorTargetUnknown(target);
|
614
|
+
}
|
615
|
+
}
|
592
616
|
}
|
@@ -11,60 +11,74 @@ import {TimestampLib} from "../type/Timestamp.sol";
|
|
11
11
|
import {VersionPart, VersionPartLib} from "../type/Version.sol";
|
12
12
|
|
13
13
|
contract Authorization
|
14
|
-
|
14
|
+
is IAuthorization
|
15
15
|
{
|
16
|
-
|
17
|
-
string public constant ROLE_NAME_SUFFIX = "Role";
|
18
|
-
string public constant SERVICE_ROLE_NAME_SUFFIX = "ServiceRole";
|
16
|
+
uint256 public constant GIF_RELEASE = 3;
|
19
17
|
|
20
|
-
|
21
|
-
|
18
|
+
string public constant ROLE_NAME_SUFFIX = "Role";
|
19
|
+
string public constant SERVICE_ROLE_NAME_SUFFIX = "ServiceRole";
|
22
20
|
|
23
|
-
|
24
|
-
|
21
|
+
ObjectType[] internal _serviceDomains;
|
22
|
+
mapping(ObjectType domain => Str target) internal _serviceTarget;
|
25
23
|
|
26
|
-
|
27
|
-
|
24
|
+
string internal _mainTargetName = "Component";
|
25
|
+
Str[] internal _targets;
|
28
26
|
|
29
|
-
|
30
|
-
|
27
|
+
mapping(Str target => RoleId roleid) internal _targetRole;
|
28
|
+
mapping(Str target => bool exists) internal _targetExists;
|
31
29
|
|
30
|
+
RoleId[] internal _roles;
|
31
|
+
mapping(RoleId role => RoleInfo info) internal _roleInfo;
|
32
32
|
|
33
|
-
|
34
|
-
|
33
|
+
mapping(Str target => RoleId[] authorizedRoles) internal _authorizedRoles;
|
34
|
+
mapping(Str target => mapping(RoleId authorizedRole => IAccess.FunctionInfo[] functions)) internal _authorizedFunctions;
|
35
35
|
|
36
|
-
|
37
|
-
|
38
|
-
|
36
|
+
|
37
|
+
constructor(string memory mainTargetName) {
|
38
|
+
_mainTargetName = mainTargetName;
|
39
|
+
|
40
|
+
_setupServiceTargets();
|
41
|
+
_setupRoles();
|
42
|
+
_setupTargets();
|
43
|
+
_setupTargetAuthorizations();
|
44
|
+
}
|
45
|
+
|
46
|
+
function getServiceDomains() external view returns(ObjectType[] memory serviceDomains) {
|
47
|
+
return _serviceDomains;
|
48
|
+
}
|
49
|
+
|
50
|
+
function getServiceRole(ObjectType serviceDomain) public virtual pure returns (RoleId serviceRoleId) {
|
51
|
+
return RoleIdLib.roleForTypeAndVersion(
|
52
|
+
serviceDomain,
|
53
|
+
getRelease());
|
39
54
|
}
|
40
55
|
|
41
|
-
function
|
42
|
-
return
|
56
|
+
function getServiceTarget(ObjectType serviceDomain) external view returns(Str serviceTarget) {
|
57
|
+
return _serviceTarget[serviceDomain];
|
43
58
|
}
|
44
59
|
|
45
60
|
function getRoles() external view returns(RoleId[] memory roles) {
|
46
61
|
return _roles;
|
47
62
|
}
|
48
63
|
|
49
|
-
function
|
50
|
-
return
|
51
|
-
serviceDomain, getRelease());
|
64
|
+
function roleExists(RoleId roleId) public view returns(bool exists) {
|
65
|
+
return _roleInfo[roleId].roleType != RoleType.Undefined;
|
52
66
|
}
|
53
67
|
|
54
68
|
function getRoleInfo(RoleId roleId) external view returns (RoleInfo memory info) {
|
55
69
|
return _roleInfo[roleId];
|
56
70
|
}
|
57
71
|
|
58
|
-
function
|
59
|
-
return
|
72
|
+
function getTargetName() public virtual view returns (string memory name) {
|
73
|
+
return _mainTargetName;
|
60
74
|
}
|
61
75
|
|
62
|
-
function
|
63
|
-
|
64
|
-
|
65
|
-
}
|
76
|
+
function getMainTarget() public view returns(Str) {
|
77
|
+
return getTarget(_mainTargetName);
|
78
|
+
}
|
66
79
|
|
67
|
-
|
80
|
+
function getTarget(string memory targetName) public view returns(Str target) {
|
81
|
+
return StrLib.toStr(targetName);
|
68
82
|
}
|
69
83
|
|
70
84
|
function getTargets() external view returns(Str[] memory targets) {
|
@@ -87,26 +101,60 @@ contract Authorization
|
|
87
101
|
return _authorizedFunctions[target][roleId];
|
88
102
|
}
|
89
103
|
|
90
|
-
|
91
|
-
|
92
|
-
|
104
|
+
function getRelease() public virtual pure returns(VersionPart release) {
|
105
|
+
return VersionPartLib.toVersionPart(GIF_RELEASE);
|
106
|
+
}
|
107
|
+
|
108
|
+
/// @dev Sets up the relevant service targets for the component.
|
109
|
+
/// Overwrite this function for a specific component.
|
110
|
+
function _setupServiceTargets() internal virtual { }
|
93
111
|
|
94
|
-
/// @dev
|
95
|
-
///
|
112
|
+
/// @dev Sets up the relevant (non-service) targets for the component.
|
113
|
+
/// Overwrite this function for a specific component.
|
96
114
|
function _setupTargets() internal virtual { }
|
97
115
|
|
98
|
-
/// @dev
|
116
|
+
/// @dev Sets up the relevant roles for the component.
|
117
|
+
/// Overwrite this function for a specific component.
|
99
118
|
function _setupRoles() internal virtual {}
|
100
119
|
|
101
|
-
/// @dev
|
120
|
+
/// @dev Sets up the relevant target authorizations for the component.
|
121
|
+
/// Overwrite this function for a specific realease.
|
102
122
|
function _setupTargetAuthorizations() internal virtual {}
|
103
123
|
|
124
|
+
|
125
|
+
/// @dev Add the service target role for the specified service domain
|
126
|
+
function _addServiceTargetWithRole(ObjectType serviceDomain) internal {
|
127
|
+
// add service domain
|
128
|
+
_serviceDomains.push(serviceDomain);
|
129
|
+
|
130
|
+
// get versioned target name
|
131
|
+
string memory serviceTargetName = ObjectTypeLib.toVersionedName(
|
132
|
+
ObjectTypeLib.toName(serviceDomain),
|
133
|
+
"Service",
|
134
|
+
getRelease().toInt());
|
135
|
+
|
136
|
+
_serviceTarget[serviceDomain] = StrLib.toStr(serviceTargetName);
|
137
|
+
|
138
|
+
RoleId serviceRoleId = getServiceRole(serviceDomain);
|
139
|
+
string memory serviceRoleName = ObjectTypeLib.toVersionedName(
|
140
|
+
ObjectTypeLib.toName(serviceDomain),
|
141
|
+
"ServiceRole",
|
142
|
+
getRelease().toInt());
|
143
|
+
|
144
|
+
_addTargetWithRole(
|
145
|
+
serviceTargetName,
|
146
|
+
serviceRoleId,
|
147
|
+
serviceRoleName);
|
148
|
+
}
|
149
|
+
|
150
|
+
|
104
151
|
/// @dev Use this method to to add an authorized role.
|
105
152
|
function _addRole(RoleId roleId, RoleInfo memory info) internal {
|
106
153
|
_roles.push(roleId);
|
107
154
|
_roleInfo[roleId] = info;
|
108
155
|
}
|
109
156
|
|
157
|
+
|
110
158
|
/// @dev Add a contract role for the provided role id and name.
|
111
159
|
function _addContractRole(RoleId roleId, string memory name) internal {
|
112
160
|
_addRole(
|
@@ -118,6 +166,7 @@ contract Authorization
|
|
118
166
|
name));
|
119
167
|
}
|
120
168
|
|
169
|
+
|
121
170
|
/// @dev Add the versioned service role for the specified service domain
|
122
171
|
function _addServiceRole(ObjectType serviceDomain) internal {
|
123
172
|
_addContractRole(
|
@@ -128,10 +177,12 @@ contract Authorization
|
|
128
177
|
getRelease().toInt()));
|
129
178
|
}
|
130
179
|
|
180
|
+
|
131
181
|
function _addComponentTargetWithRole(ObjectType componentType) internal {
|
132
182
|
_addComponentTargetWithRole(componentType, 0);
|
133
183
|
}
|
134
184
|
|
185
|
+
|
135
186
|
function _addComponentTargetWithRole(ObjectType componentType, uint64 index) internal {
|
136
187
|
_addTargetWithRole(
|
137
188
|
getTargetName(),
|
@@ -140,6 +191,7 @@ contract Authorization
|
|
140
191
|
getTargetName()));
|
141
192
|
}
|
142
193
|
|
194
|
+
|
143
195
|
/// @dev Add a contract role for the provided role id and name.
|
144
196
|
function _addCustomRole(RoleId roleId, RoleId adminRoleId, uint32 maxMemberCount, string memory name) internal {
|
145
197
|
_addRole(
|
@@ -177,11 +229,13 @@ contract Authorization
|
|
177
229
|
}
|
178
230
|
}
|
179
231
|
|
232
|
+
|
180
233
|
/// @dev Use this method to to add an authorized target.
|
181
234
|
function _addTarget(string memory name) internal {
|
182
235
|
_addTargetWithRole(name, RoleIdLib.zero(), "");
|
183
236
|
}
|
184
237
|
|
238
|
+
|
185
239
|
/// @dev Use this method to authorize the specified role to access the target.
|
186
240
|
function _authorizeForTarget(string memory target, RoleId authorizedRoleId)
|
187
241
|
internal
|
@@ -192,6 +246,7 @@ contract Authorization
|
|
192
246
|
return _authorizedFunctions[targetStr][authorizedRoleId];
|
193
247
|
}
|
194
248
|
|
249
|
+
|
195
250
|
/// @dev Use this method to authorize a specific function authorization
|
196
251
|
function _authorize(IAccess.FunctionInfo[] storage functions, bytes4 selector, string memory name) internal {
|
197
252
|
functions.push(
|
@@ -201,13 +256,25 @@ contract Authorization
|
|
201
256
|
createdAt: TimestampLib.blockTimestamp()}));
|
202
257
|
}
|
203
258
|
|
204
|
-
|
259
|
+
|
260
|
+
/// @dev role id for targets registry, staking and instance
|
261
|
+
function _toTargetRoleId(ObjectType targetDomain)
|
262
|
+
internal
|
263
|
+
pure
|
264
|
+
returns (RoleId targetRoleId)
|
265
|
+
{
|
266
|
+
return RoleIdLib.roleForType(targetDomain);
|
267
|
+
}
|
268
|
+
|
269
|
+
|
270
|
+
function _toTargetRoleName(string memory targetName) internal pure returns (string memory) {
|
205
271
|
return string(
|
206
272
|
abi.encodePacked(
|
207
273
|
targetName,
|
208
274
|
ROLE_NAME_SUFFIX));
|
209
275
|
}
|
210
276
|
|
277
|
+
|
211
278
|
/// @dev creates a role info object from the provided parameters
|
212
279
|
function _toRoleInfo(RoleId adminRoleId, RoleType roleType, uint32 maxMemberCount, string memory name) internal view returns (RoleInfo memory info) {
|
213
280
|
return RoleInfo({
|
@@ -215,7 +282,8 @@ contract Authorization
|
|
215
282
|
adminRoleId: adminRoleId,
|
216
283
|
roleType: roleType,
|
217
284
|
maxMemberCount: maxMemberCount,
|
218
|
-
createdAt: TimestampLib.blockTimestamp()
|
285
|
+
createdAt: TimestampLib.blockTimestamp(),
|
286
|
+
pausedAt: TimestampLib.max()});
|
219
287
|
}
|
220
288
|
}
|
221
289
|
|
@@ -41,9 +41,10 @@ interface IAccessAdmin is
|
|
41
41
|
// grant/revoke/renounce role
|
42
42
|
error ErrorRoleUnknown(RoleId roleId);
|
43
43
|
error ErrorRoleIsLocked(RoleId roleId);
|
44
|
-
error
|
44
|
+
error ErrorRoleIsPaused(RoleId roleId);
|
45
45
|
error ErrorRoleMembersLimitReached(RoleId roleId, uint256 memberCountLimit);
|
46
|
-
error
|
46
|
+
error ErrorRoleMemberNotContract(RoleId roleId, address notContract);
|
47
|
+
error ErrorRoleMemberRemovalDisabled(RoleId roleId, address expectedMember);
|
47
48
|
|
48
49
|
// create target
|
49
50
|
error ErrorTargetAlreadyCreated(address target, string name);
|
@@ -54,6 +55,7 @@ interface IAccessAdmin is
|
|
54
55
|
|
55
56
|
// lock target
|
56
57
|
error ErrorTagetNotLockable();
|
58
|
+
error ErrorTargetAlreadyLocked(address target, bool isLocked);
|
57
59
|
|
58
60
|
// authorize target functions
|
59
61
|
error ErrorAuthorizeForAdminRoleInvalid(address target);
|
@@ -11,16 +11,18 @@ interface IAuthorization is
|
|
11
11
|
IAccess
|
12
12
|
{
|
13
13
|
|
14
|
-
/// @dev Returns the
|
15
|
-
|
16
|
-
function getRelease() external view returns(VersionPart release);
|
17
|
-
|
18
|
-
/// @dev Returns the list of involved roles.
|
19
|
-
function getRoles() external view returns(RoleId[] memory roles);
|
14
|
+
/// @dev Returns the list of service targets.
|
15
|
+
function getServiceDomains() external view returns(ObjectType[] memory serviceDomains);
|
20
16
|
|
21
17
|
/// @dev Returns the service role for the specified service domain.
|
22
18
|
function getServiceRole(ObjectType serviceDomain) external pure returns (RoleId serviceRoleId);
|
23
19
|
|
20
|
+
/// @dev Returns the service target for the specified domain.
|
21
|
+
function getServiceTarget(ObjectType serviceDomain) external view returns(Str serviceTarget);
|
22
|
+
|
23
|
+
/// @dev Returns the list of involved roles.
|
24
|
+
function getRoles() external view returns(RoleId[] memory roles);
|
25
|
+
|
24
26
|
/// @dev Returns the name for the provided role id.
|
25
27
|
function getRoleInfo(RoleId roleId) external view returns (RoleInfo memory roleInfo);
|
26
28
|
|
@@ -33,7 +35,7 @@ interface IAuthorization is
|
|
33
35
|
function getTargetName() external view returns (string memory name);
|
34
36
|
|
35
37
|
/// @dev Returns the main target.
|
36
|
-
function
|
38
|
+
function getMainTarget() external view returns(Str target);
|
37
39
|
|
38
40
|
/// @dev Returns the complete list of targets.
|
39
41
|
function getTargets() external view returns(Str[] memory targets);
|
@@ -50,5 +52,9 @@ interface IAuthorization is
|
|
50
52
|
|
51
53
|
/// @dev For the given target and role id the list of authorized functions is returned
|
52
54
|
function getAuthorizedFunctions(Str target, RoleId roleId) external view returns(FunctionInfo[] memory authorizatedFunctions);
|
55
|
+
|
56
|
+
/// @dev Returns the release (VersionPart) for which the authorizations are defined by this contract.
|
57
|
+
/// Matches with the release returned by the linked service authorization.
|
58
|
+
function getRelease() external view returns(VersionPart release);
|
53
59
|
}
|
54
60
|
|
@@ -1,11 +1,13 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
+
import {IERC165} from "@openzeppelin/contracts/utils/introspection/IERC165.sol";
|
5
|
+
|
4
6
|
import {IAccess} from "../authorization/IAccess.sol";
|
5
7
|
import {ObjectType} from "../type/ObjectType.sol";
|
6
8
|
import {VersionPart} from "../type/Version.sol";
|
7
9
|
|
8
|
-
interface IServiceAuthorization {
|
10
|
+
interface IServiceAuthorization is IERC165 {
|
9
11
|
|
10
12
|
/// @dev Returns the commit hash representing the deployed release
|
11
13
|
function getCommitHash()
|
@@ -0,0 +1,38 @@
|
|
1
|
+
// SPDX-License-Identifier: UNLICENSED
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {AccessManager} from "@openzeppelin/contracts/access/manager/AccessManager.sol";
|
5
|
+
|
6
|
+
abstract contract ReleaseAccessManager is
|
7
|
+
AccessManager
|
8
|
+
{
|
9
|
+
bool private _releaseIsLocked;
|
10
|
+
|
11
|
+
function setReleaseLocked(bool locked)
|
12
|
+
external
|
13
|
+
onlyAuthorized()
|
14
|
+
{
|
15
|
+
_releaseIsLocked = locked;
|
16
|
+
}
|
17
|
+
|
18
|
+
function isReleaseLocked()
|
19
|
+
external
|
20
|
+
view
|
21
|
+
returns (bool isLocked)
|
22
|
+
{
|
23
|
+
return _releaseIsLocked;
|
24
|
+
}
|
25
|
+
|
26
|
+
function isTargetClosed(address target)
|
27
|
+
public
|
28
|
+
virtual override
|
29
|
+
view
|
30
|
+
returns (bool)
|
31
|
+
{
|
32
|
+
if (_releaseIsLocked) {
|
33
|
+
return true;
|
34
|
+
}
|
35
|
+
|
36
|
+
return super.isTargetClosed(target);
|
37
|
+
}
|
38
|
+
}
|