@etherisc/gif-next 0.0.2-e769e2e-077 → 0.0.2-e79d227-681
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 +77 -10
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +1293 -0
- 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 +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 +414 -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 +1060 -0
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +295 -0
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +167 -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 +4 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +253 -0
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +1324 -0
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +470 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +154 -546
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +380 -229
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +198 -96
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +186 -238
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +223 -47
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1429 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +502 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +1979 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +470 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1430 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1177 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1606 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2281 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +4 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +808 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +153 -86
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +181 -119
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +174 -215
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1666 -0
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +574 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +876 -160
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +260 -268
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +163 -81
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +506 -338
- 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/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 +223 -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 +4 -0
- package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +961 -0
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +478 -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 +776 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +709 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +877 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +990 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +766 -0
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +1254 -0
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +502 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +456 -187
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +218 -80
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +264 -26
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +115 -354
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +464 -223
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +152 -682
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +590 -382
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +190 -76
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +147 -161
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +147 -77
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +1148 -0
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +470 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +343 -168
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +200 -90
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +88 -8
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +196 -7
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +364 -121
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +134 -86
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +176 -160
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
- package/artifacts/contracts/product/{IProductService.sol/IProductService.json → IRiskService.sol/IRiskService.json} +51 -3
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +475 -294
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +199 -81
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +229 -275
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +172 -102
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +201 -486
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +638 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +718 -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 +412 -35
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +225 -196
- 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 +761 -87
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1899 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +278 -306
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +154 -78
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +205 -0
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1067 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +272 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +185 -135
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +79 -274
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +626 -252
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +209 -99
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +55 -101
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +488 -0
- 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 +74 -79
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +561 -13
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +120 -108
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +45 -13
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +34 -3
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +23 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +16 -30
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +36 -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 +49 -1
- 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 +129 -360
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +55 -98
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +42 -62
- 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 +26 -55
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +20 -124
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +62 -87
- 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 +55 -101
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +697 -25
- 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 +4 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +462 -634
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +546 -48
- 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 +613 -871
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +205 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +185 -81
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +587 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +633 -173
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +166 -68
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2283 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +607 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +121 -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 +28 -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/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 +47 -4
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +149 -2
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +19 -19
- 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 +99 -5
- 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 +124 -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 +15 -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 +71 -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 +618 -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 +616 -0
- package/contracts/authorization/AccessManagerCloneable.sol +16 -0
- package/contracts/authorization/Authorization.sol +289 -0
- package/contracts/authorization/IAccess.sol +49 -0
- package/contracts/authorization/IAccessAdmin.sol +137 -0
- package/contracts/authorization/IAuthorization.sol +60 -0
- package/contracts/authorization/IServiceAuthorization.sol +40 -0
- package/contracts/authorization/ReleaseAccessManager.sol +38 -0
- package/contracts/authorization/ServiceAuthorization.sol +106 -0
- package/contracts/distribution/BasicDistribution.sol +139 -0
- package/contracts/distribution/BasicDistributionAuthorization.sol +47 -0
- package/contracts/distribution/Distribution.sol +145 -124
- package/contracts/distribution/DistributionService.sol +156 -99
- package/contracts/distribution/DistributionServiceManager.sol +13 -25
- package/contracts/distribution/IDistributionComponent.sol +27 -41
- package/contracts/distribution/IDistributionService.sol +29 -10
- package/contracts/examples/fire/DamageLevel.sol +59 -0
- package/contracts/examples/fire/FirePool.sol +86 -0
- package/contracts/examples/fire/FirePoolAuthorization.sol +34 -0
- package/contracts/examples/fire/FireProduct.sol +431 -0
- package/contracts/examples/fire/FireProductAuthorization.sol +44 -0
- package/contracts/examples/fire/FireUSD.sol +26 -0
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +58 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +137 -0
- package/contracts/examples/unpermissioned/SimplePool.sol +108 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +345 -0
- package/contracts/instance/BundleSet.sol +130 -0
- package/contracts/instance/IInstance.sol +39 -44
- package/contracts/instance/IInstanceService.sol +33 -42
- package/contracts/instance/Instance.sol +137 -124
- package/contracts/instance/InstanceAdmin.sol +278 -0
- package/contracts/instance/InstanceAuthorizationV3.sol +217 -0
- package/contracts/instance/InstanceReader.sol +249 -36
- package/contracts/instance/InstanceService.sol +227 -151
- package/contracts/instance/InstanceServiceManager.sol +14 -29
- package/contracts/instance/InstanceStore.sol +85 -57
- package/contracts/instance/RiskSet.sol +119 -0
- package/contracts/instance/base/BalanceStore.sol +12 -7
- 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/ObjectSet.sol +78 -0
- package/contracts/instance/module/IAccess.sol +2 -10
- package/contracts/instance/module/IBundle.sol +1 -1
- package/contracts/instance/module/IComponents.sol +11 -13
- package/contracts/instance/module/IDistribution.sol +0 -1
- package/contracts/instance/module/IPolicy.sol +26 -25
- package/contracts/instance/module/IRisk.sol +1 -0
- package/contracts/mock/Dip.sol +26 -0
- package/contracts/oracle/BasicOracle.sol +47 -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 +66 -0
- package/contracts/oracle/Oracle.sol +156 -0
- package/contracts/oracle/OracleService.sol +309 -0
- package/contracts/oracle/OracleServiceManager.sol +39 -0
- package/contracts/pool/BasicPool.sol +175 -0
- package/contracts/pool/BasicPoolAuthorization.sol +68 -0
- package/contracts/pool/BundleService.sol +232 -122
- package/contracts/pool/BundleServiceManager.sol +13 -25
- package/contracts/pool/IBundleService.sol +34 -18
- package/contracts/pool/IPoolComponent.sol +20 -70
- package/contracts/pool/IPoolService.sol +57 -51
- package/contracts/pool/Pool.sol +208 -162
- package/contracts/pool/PoolService.sol +372 -181
- package/contracts/pool/PoolServiceManager.sol +12 -24
- package/contracts/product/ApplicationService.sol +90 -84
- package/contracts/product/ApplicationServiceManager.sol +12 -9
- package/contracts/product/BasicProduct.sol +49 -0
- package/contracts/product/BasicProductAuthorization.sol +42 -0
- package/contracts/product/ClaimService.sol +331 -153
- package/contracts/product/ClaimServiceManager.sol +12 -9
- package/contracts/product/IApplicationService.sol +7 -3
- package/contracts/product/IClaimService.sol +35 -5
- package/contracts/product/IPolicyService.sol +47 -35
- package/contracts/product/IPricingService.sol +11 -11
- package/contracts/product/IProductComponent.sol +26 -9
- package/contracts/product/{IProductService.sol → IRiskService.sol} +2 -2
- package/contracts/product/PolicyService.sol +524 -262
- package/contracts/product/PolicyServiceManager.sol +12 -27
- package/contracts/product/PricingService.sol +64 -64
- package/contracts/product/PricingServiceManager.sol +12 -24
- package/contracts/product/Product.sol +189 -139
- package/contracts/product/{ProductService.sol → RiskService.sol} +35 -50
- package/contracts/product/RiskServiceManager.sol +39 -0
- package/contracts/registry/ChainNft.sol +68 -37
- package/contracts/registry/IRegistry.sol +90 -28
- package/contracts/registry/IRegistryService.sol +26 -43
- package/contracts/registry/ITransferInterceptor.sol +1 -2
- package/contracts/registry/Registry.sol +424 -228
- package/contracts/registry/RegistryAdmin.sol +451 -0
- package/contracts/registry/RegistryService.sol +63 -149
- package/contracts/registry/RegistryServiceManager.sol +23 -30
- package/contracts/registry/ReleaseLifecycle.sol +30 -0
- package/contracts/registry/ReleaseRegistry.sol +485 -0
- package/contracts/registry/ServiceAuthorizationV3.sol +175 -0
- package/contracts/registry/TokenRegistry.sol +187 -59
- package/contracts/shared/Component.sol +56 -125
- package/contracts/shared/ComponentService.sol +411 -201
- package/contracts/shared/ComponentServiceManager.sol +10 -7
- package/contracts/shared/ComponentVerifyingService.sol +40 -23
- package/contracts/shared/ContractLib.sol +224 -0
- package/contracts/shared/IComponent.sol +11 -18
- package/contracts/shared/IComponentService.sol +52 -13
- package/contracts/shared/IInstanceLinkedComponent.sol +11 -16
- package/contracts/shared/IKeyValueStore.sol +2 -1
- package/contracts/shared/ILifecycle.sol +3 -2
- package/contracts/shared/INftOwnable.sol +3 -1
- package/contracts/shared/IPolicyHolder.sol +12 -17
- package/contracts/shared/IRegisterable.sol +11 -0
- package/contracts/shared/IService.sol +9 -2
- package/contracts/shared/{ERC165.sol → InitializableERC165.sol} +4 -4
- package/contracts/shared/InstanceLinkedComponent.sol +103 -43
- package/contracts/shared/KeyValueStore.sol +30 -68
- package/contracts/shared/Lifecycle.sol +30 -63
- package/contracts/shared/NftIdSet.sol +65 -0
- package/contracts/shared/NftOwnable.sol +31 -22
- package/contracts/shared/PolicyHolder.sol +18 -50
- package/contracts/shared/Registerable.sol +19 -11
- package/contracts/shared/RegistryLinked.sol +9 -14
- package/contracts/shared/Service.sol +44 -37
- package/contracts/shared/TokenHandler.sol +358 -27
- package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
- package/contracts/staking/IStaking.sol +133 -37
- package/contracts/staking/IStakingService.sol +93 -41
- package/contracts/staking/StakeManagerLib.sol +224 -0
- package/contracts/staking/Staking.sol +394 -101
- package/contracts/staking/StakingLifecycle.sol +23 -0
- package/contracts/staking/StakingManager.sol +24 -18
- package/contracts/staking/StakingReader.sol +190 -0
- package/contracts/staking/StakingService.sol +282 -42
- package/contracts/staking/StakingServiceManager.sol +10 -7
- package/contracts/staking/StakingStore.sol +605 -0
- package/contracts/staking/TargetManagerLib.sol +211 -0
- package/contracts/type/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +39 -3
- package/contracts/type/Blocknumber.sol +20 -2
- package/contracts/type/ClaimId.sol +6 -1
- package/contracts/type/Fee.sol +1 -1
- package/contracts/type/Key32.sol +2 -2
- package/contracts/type/Key32Set.sol +62 -0
- package/contracts/type/NftId.sol +16 -4
- package/contracts/type/NftIdSet.sol +1 -1
- package/contracts/type/ObjectType.sol +178 -65
- package/contracts/type/PayoutId.sol +10 -10
- package/contracts/type/Referral.sol +2 -1
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/type/RiskId.sol +31 -5
- package/contracts/type/RoleId.sol +98 -74
- package/contracts/type/Seconds.sol +48 -1
- package/contracts/type/Selector.sol +102 -0
- package/contracts/type/StateId.sol +41 -2
- package/contracts/type/String.sol +53 -0
- package/contracts/type/Timestamp.sol +17 -3
- package/contracts/type/UFixed.sol +38 -9
- package/contracts/type/Version.sol +4 -2
- package/contracts/{shared → upgradeability}/ProxyManager.sol +90 -27
- package/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol +1 -3
- package/contracts/{shared → upgradeability}/Versionable.sol +2 -2
- package/package.json +11 -7
- 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 -636
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -308
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +0 -4
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +0 -688
- 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/ProxyManager.sol/ProxyManager.dbg.json +0 -4
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -569
- 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/BundleManager.sol +0 -126
- package/contracts/instance/InstanceAccessManager.sol +0 -543
- package/contracts/instance/InstanceAuthorizationsLib.sol +0 -336
- package/contracts/instance/base/ObjectManager.sol +0 -82
- package/contracts/product/ProductServiceManager.sol +0 -54
- package/contracts/registry/RegistryAccessManager.sol +0 -213
- package/contracts/registry/ReleaseManager.sol +0 -375
- package/contracts/registry/ServiceAuthorizationsLib.sol +0 -173
- package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +0 -13
- /package/contracts/{shared → upgradeability}/IVersionable.sol +0 -0
@@ -3,54 +3,37 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
5
5
|
|
6
|
-
import {
|
7
|
-
import {
|
8
|
-
import {
|
9
|
-
import {
|
10
|
-
import {RoleId, RoleIdLib, eqRoleId, ADMIN_ROLE, INSTANCE_ROLE, INSTANCE_OWNER_ROLE} from "../type/RoleId.sol";
|
11
|
-
import {VersionPart, VersionPartLib} from "../type/Version.sol";
|
12
|
-
import {ClaimId} from "../type/ClaimId.sol";
|
13
|
-
import {ReferralId} from "../type/Referral.sol";
|
14
|
-
import {PayoutId} from "../type/PayoutId.sol";
|
15
|
-
import {DistributorType} from "../type/DistributorType.sol";
|
16
|
-
|
17
|
-
import {Registerable} from "../shared/Registerable.sol";
|
18
|
-
import {TokenHandler} from "../shared/TokenHandler.sol";
|
19
|
-
|
20
|
-
import {IRegistry} from "../registry/IRegistry.sol";
|
21
|
-
|
6
|
+
import {Amount} from "../type/Amount.sol";
|
7
|
+
import {BundleSet} from "./BundleSet.sol";
|
8
|
+
import {RiskSet} from "./RiskSet.sol";
|
9
|
+
import {COMPONENT, INSTANCE} from "../type/ObjectType.sol";
|
22
10
|
import {IInstance} from "./IInstance.sol";
|
11
|
+
import {IComponentService} from "../shared/IComponentService.sol";
|
12
|
+
import {IInstanceService} from "./IInstanceService.sol";
|
23
13
|
import {InstanceReader} from "./InstanceReader.sol";
|
24
|
-
import {
|
25
|
-
import {BundleManager} from "./BundleManager.sol";
|
14
|
+
import {InstanceAdmin} from "./InstanceAdmin.sol";
|
26
15
|
import {InstanceStore} from "./InstanceStore.sol";
|
27
|
-
|
28
|
-
import {
|
29
|
-
|
30
|
-
import {
|
31
|
-
import {
|
32
|
-
import {
|
33
|
-
import {
|
34
|
-
import {IRisk} from "./module/IRisk.sol";
|
35
|
-
|
36
|
-
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
37
|
-
import {IPoolService} from "../pool/IPoolService.sol";
|
38
|
-
import {IProductService} from "../product/IProductService.sol";
|
39
|
-
import {IPolicyService} from "../product/IPolicyService.sol";
|
40
|
-
import {IBundleService} from "../pool/IBundleService.sol";
|
16
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
17
|
+
import {NftId} from "../type/NftId.sol";
|
18
|
+
import {Registerable} from "../shared/Registerable.sol";
|
19
|
+
import {RoleId} from "../type/RoleId.sol";
|
20
|
+
import {Seconds} from "../type/Seconds.sol";
|
21
|
+
import {UFixed} from "../type/UFixed.sol";
|
22
|
+
import {VersionPart, VersionPartLib} from "../type/Version.sol";
|
41
23
|
|
42
24
|
contract Instance is
|
43
25
|
IInstance,
|
44
26
|
AccessManagedUpgradeable,
|
45
27
|
Registerable
|
46
28
|
{
|
47
|
-
uint256 public constant GIF_MAJOR_VERSION = 3;
|
48
|
-
|
49
29
|
bool private _initialized;
|
50
30
|
|
51
|
-
|
31
|
+
IComponentService internal _componentService;
|
32
|
+
IInstanceService internal _instanceService;
|
33
|
+
InstanceAdmin internal _instanceAdmin;
|
52
34
|
InstanceReader internal _instanceReader;
|
53
|
-
|
35
|
+
BundleSet internal _bundleSet;
|
36
|
+
RiskSet internal _riskSet;
|
54
37
|
InstanceStore internal _instanceStore;
|
55
38
|
|
56
39
|
modifier onlyChainNft() {
|
@@ -60,53 +43,135 @@ contract Instance is
|
|
60
43
|
_;
|
61
44
|
}
|
62
45
|
|
63
|
-
function initialize(
|
46
|
+
function initialize(
|
47
|
+
InstanceAdmin instanceAdmin,
|
48
|
+
InstanceStore instanceStore,
|
49
|
+
BundleSet bundleSet,
|
50
|
+
RiskSet riskSet,
|
51
|
+
InstanceReader instanceReader,
|
52
|
+
IRegistry registry,
|
53
|
+
address initialOwner
|
54
|
+
)
|
64
55
|
external
|
65
56
|
initializer()
|
66
57
|
{
|
67
|
-
|
68
|
-
|
58
|
+
_instanceAdmin = instanceAdmin;
|
59
|
+
if(_instanceAdmin.authority() == address(0)) {
|
60
|
+
revert ErrorInstanceInstanceAdminZero();
|
69
61
|
}
|
70
62
|
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
63
|
+
// set authority to instance admin authority
|
64
|
+
__AccessManaged_init(_instanceAdmin.authority());
|
65
|
+
|
66
|
+
// setup instance object info
|
67
|
+
_initializeRegisterable(
|
68
|
+
address(registry),
|
69
|
+
registry.getNftId(),
|
70
|
+
INSTANCE(),
|
71
|
+
true,
|
72
|
+
initialOwner,
|
73
|
+
"");
|
74
|
+
|
75
|
+
// store instance supporting contracts
|
76
|
+
_instanceStore = instanceStore;
|
77
|
+
_bundleSet = bundleSet;
|
78
|
+
_riskSet = riskSet;
|
79
|
+
_instanceReader = instanceReader;
|
80
|
+
|
81
|
+
// initialize instance supporting contracts
|
82
|
+
_instanceStore.initialize();
|
83
|
+
_bundleSet.initialize();
|
84
|
+
_riskSet.initialize();
|
85
|
+
_instanceReader.initialize();
|
86
|
+
|
87
|
+
_componentService = IComponentService(
|
88
|
+
getRegistry().getServiceAddress(
|
89
|
+
COMPONENT(),
|
90
|
+
getRelease()));
|
91
|
+
|
92
|
+
_instanceService = IInstanceService(
|
93
|
+
getRegistry().getServiceAddress(
|
94
|
+
INSTANCE(),
|
95
|
+
getRelease()));
|
96
|
+
|
97
|
+
_registerInterface(type(IInstance).interfaceId);
|
98
|
+
}
|
99
|
+
|
100
|
+
//--- ProductRegistration ----------------------------------------------//
|
101
|
+
function registerProduct(address product)
|
102
|
+
external
|
103
|
+
onlyOwner()
|
104
|
+
returns (NftId productNftId)
|
105
|
+
{
|
106
|
+
return _componentService.registerProduct(product);
|
107
|
+
}
|
108
|
+
|
109
|
+
//--- Staking ----------------------------------------------------------//
|
110
|
+
|
111
|
+
function setStakingLockingPeriod(Seconds stakeLockingPeriod)
|
112
|
+
external
|
113
|
+
onlyOwner()
|
114
|
+
{
|
115
|
+
_instanceService.setStakingLockingPeriod(stakeLockingPeriod);
|
116
|
+
}
|
117
|
+
|
118
|
+
function setStakingRewardRate(UFixed rewardRate)
|
119
|
+
external
|
120
|
+
onlyOwner()
|
121
|
+
{
|
122
|
+
_instanceService.setStakingRewardRate(rewardRate);
|
123
|
+
}
|
75
124
|
|
76
|
-
|
125
|
+
function refillStakingRewardReserves(Amount dipAmount)
|
126
|
+
external
|
127
|
+
onlyOwner()
|
128
|
+
{
|
129
|
+
address instanceOwner = msg.sender;
|
130
|
+
_instanceService.refillStakingRewardReserves(instanceOwner, dipAmount);
|
131
|
+
}
|
132
|
+
|
133
|
+
function withdrawStakingRewardReserves(Amount dipAmount)
|
134
|
+
external
|
135
|
+
onlyOwner()
|
136
|
+
returns (Amount newBalance)
|
137
|
+
{
|
138
|
+
return _instanceService.withdrawStakingRewardReserves(dipAmount);
|
77
139
|
}
|
78
140
|
|
79
141
|
//--- Roles ------------------------------------------------------------//
|
80
142
|
|
81
143
|
function createRole(string memory roleName, string memory adminName)
|
82
144
|
external
|
83
|
-
|
145
|
+
onlyOwner()
|
84
146
|
returns (RoleId roleId, RoleId admin)
|
85
147
|
{
|
86
|
-
|
148
|
+
// TODO refactor
|
149
|
+
// (roleId, admin) = _instanceAdmin.createRole(roleName, adminName);
|
87
150
|
}
|
88
151
|
|
89
152
|
function grantRole(RoleId roleId, address account)
|
90
153
|
external
|
91
|
-
|
154
|
+
onlyOwner()
|
92
155
|
{
|
93
|
-
|
156
|
+
_instanceAdmin.grantRole(roleId, account);
|
94
157
|
}
|
95
158
|
|
96
159
|
function revokeRole(RoleId roleId, address account)
|
97
160
|
external
|
98
|
-
|
161
|
+
onlyOwner()
|
99
162
|
{
|
100
|
-
|
163
|
+
// TODO refactor
|
164
|
+
// AccessManagerExtendedInitializeable(authority()).revokeRole(roleId.toInt(), account);
|
101
165
|
}
|
102
166
|
|
103
167
|
//--- Targets ------------------------------------------------------------//
|
104
168
|
|
105
169
|
function createTarget(address target, string memory name)
|
106
170
|
external
|
107
|
-
|
171
|
+
onlyOwner()
|
108
172
|
{
|
109
|
-
|
173
|
+
// TODO refactor
|
174
|
+
// _instanceAdmin.createTarget(target, name);
|
110
175
|
}
|
111
176
|
|
112
177
|
function setTargetFunctionRole(
|
@@ -115,56 +180,34 @@ contract Instance is
|
|
115
180
|
RoleId roleId
|
116
181
|
)
|
117
182
|
external
|
118
|
-
|
183
|
+
onlyOwner()
|
119
184
|
{
|
120
|
-
|
185
|
+
// TODO refactor
|
186
|
+
// _instanceAdmin.setTargetFunctionRoleByInstance(targetName, selectors, roleId);
|
121
187
|
}
|
122
188
|
|
123
189
|
function setTargetLocked(address target, bool locked)
|
124
190
|
external
|
125
|
-
|
191
|
+
onlyOwner()
|
126
192
|
{
|
127
|
-
|
193
|
+
// TODO refactor
|
194
|
+
// _instanceAdmin.setTargetLockedByInstance(target, locked);
|
128
195
|
}
|
129
196
|
|
130
|
-
//--- ITransferInterceptor
|
197
|
+
//--- ITransferInterceptor ----------------------------------------------//
|
131
198
|
|
132
|
-
function
|
133
|
-
|
134
|
-
|
135
|
-
}
|
136
|
-
|
137
|
-
function nftTransferFrom(address from, address to, uint256 tokenId) external onlyChainNft {
|
138
|
-
assert(_accessManager.revokeRole(INSTANCE_OWNER_ROLE(), from) == true);
|
139
|
-
assert(_accessManager.grantRole(INSTANCE_OWNER_ROLE(), to) == true);
|
199
|
+
function nftTransferFrom(address from, address to, uint256 tokenId, address operator) external onlyChainNft {
|
200
|
+
// TODO refactor
|
201
|
+
// _instanceAdmin.transferInstanceOwnerRole(from, to);
|
140
202
|
}
|
141
203
|
|
142
204
|
//--- initial setup functions -------------------------------------------//
|
143
205
|
|
144
|
-
function setInstanceAccessManager(InstanceAccessManager accessManager) external restricted {
|
145
|
-
if(address(_accessManager) != address(0)) {
|
146
|
-
revert ErrorInstanceInstanceAccessManagerAlreadySet(address(_accessManager));
|
147
|
-
}
|
148
|
-
if(accessManager.authority() != authority()) {
|
149
|
-
revert ErrorInstanceInstanceAccessManagerAuthorityMismatch(authority());
|
150
|
-
}
|
151
|
-
_accessManager = accessManager;
|
152
|
-
}
|
153
|
-
|
154
|
-
function setBundleManager(BundleManager bundleManager) external restricted() {
|
155
|
-
if(address(_bundleManager) != address(0)) {
|
156
|
-
revert ErrorInstanceBundleManagerAlreadySet(address(_bundleManager));
|
157
|
-
}
|
158
|
-
if(bundleManager.getInstance() != Instance(this)) {
|
159
|
-
revert ErrorInstanceBundleManagerInstanceMismatch(address(this));
|
160
|
-
}
|
161
|
-
if(bundleManager.authority() != authority()) {
|
162
|
-
revert ErrorInstanceBundleManagerAuthorityMismatch(authority());
|
163
|
-
}
|
164
|
-
_bundleManager = bundleManager;
|
165
|
-
}
|
166
206
|
|
167
|
-
function setInstanceReader(InstanceReader instanceReader)
|
207
|
+
function setInstanceReader(InstanceReader instanceReader)
|
208
|
+
external
|
209
|
+
restricted()
|
210
|
+
{
|
168
211
|
if(instanceReader.getInstance() != Instance(this)) {
|
169
212
|
revert ErrorInstanceInstanceReaderInstanceMismatch(address(this));
|
170
213
|
}
|
@@ -178,51 +221,21 @@ contract Instance is
|
|
178
221
|
return _instanceReader;
|
179
222
|
}
|
180
223
|
|
181
|
-
function
|
182
|
-
return
|
224
|
+
function getBundleSet() external view returns (BundleSet) {
|
225
|
+
return _bundleSet;
|
183
226
|
}
|
184
227
|
|
185
|
-
function
|
186
|
-
return
|
228
|
+
function getRiskSet() external view returns (RiskSet) {
|
229
|
+
return _riskSet;
|
187
230
|
}
|
188
231
|
|
189
|
-
function
|
190
|
-
|
191
|
-
revert ErrorInstanceInstanceStoreAlreadySet(address(_instanceStore));
|
192
|
-
}
|
193
|
-
if(instanceStore.authority() != authority()) {
|
194
|
-
revert ErrorInstanceInstanceStoreAuthorityMismatch(authority());
|
195
|
-
}
|
196
|
-
_instanceStore = instanceStore;
|
232
|
+
function getInstanceAdmin() external view returns (InstanceAdmin) {
|
233
|
+
return _instanceAdmin;
|
197
234
|
}
|
198
235
|
|
199
236
|
function getInstanceStore() external view returns (InstanceStore) {
|
200
237
|
return _instanceStore;
|
201
238
|
}
|
202
239
|
|
203
|
-
function getMajorVersion() external pure returns (VersionPart majorVersion) {
|
204
|
-
return VersionPartLib.toVersionPart(GIF_MAJOR_VERSION);
|
205
|
-
}
|
206
|
-
|
207
|
-
function getDistributionService() external view returns (IDistributionService) {
|
208
|
-
return IDistributionService(getRegistry().getServiceAddress(DISTRIBUTION(), VersionPart.wrap(3)));
|
209
|
-
}
|
210
|
-
|
211
|
-
function getProductService() external view returns (IProductService) {
|
212
|
-
return IProductService(getRegistry().getServiceAddress(PRODUCT(), VersionPart.wrap(3)));
|
213
|
-
}
|
214
|
-
|
215
|
-
function getPoolService() external view returns (IPoolService) {
|
216
|
-
return IPoolService(getRegistry().getServiceAddress(POOL(), VersionPart.wrap(3)));
|
217
|
-
}
|
218
|
-
|
219
|
-
function getPolicyService() external view returns (IPolicyService) {
|
220
|
-
return IPolicyService(getRegistry().getServiceAddress(POLICY(), VersionPart.wrap(3)));
|
221
|
-
}
|
222
|
-
|
223
|
-
function getBundleService() external view returns (IBundleService) {
|
224
|
-
return IBundleService(getRegistry().getServiceAddress(BUNDLE(), VersionPart.wrap(3)));
|
225
|
-
}
|
226
|
-
|
227
240
|
//--- internal view/pure functions --------------------------------------//
|
228
241
|
}
|
@@ -0,0 +1,278 @@
|
|
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 {IAuthorization} from "../authorization/IAuthorization.sol";
|
9
|
+
import {IInstanceLinkedComponent} from "../shared/IInstanceLinkedComponent.sol";
|
10
|
+
import {IAuthorization} from "../authorization/IAuthorization.sol";
|
11
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
12
|
+
import {IInstance} from "./IInstance.sol";
|
13
|
+
import {IService} from "../shared/IService.sol";
|
14
|
+
import {ObjectType, ObjectTypeLib, ALL, POOL, RELEASE} from "../type/ObjectType.sol";
|
15
|
+
import {RoleId, RoleIdLib, ADMIN_ROLE, PUBLIC_ROLE} from "../type/RoleId.sol";
|
16
|
+
import {Str, StrLib} from "../type/String.sol";
|
17
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
18
|
+
import {VersionPart} from "../type/Version.sol";
|
19
|
+
|
20
|
+
|
21
|
+
contract InstanceAdmin is
|
22
|
+
AccessAdmin
|
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
|
+
string public constant RISK_SET_TAGET_NAME = "RiskSet";
|
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
|
+
IAuthorization _instanceAuthorization;
|
42
|
+
|
43
|
+
/// @dev Only used for master instance admin.
|
44
|
+
/// Contracts created via constructor come with disabled initializers.
|
45
|
+
constructor(
|
46
|
+
address instanceAuthorization
|
47
|
+
)
|
48
|
+
AccessAdmin()
|
49
|
+
{
|
50
|
+
_instanceAuthorization = IAuthorization(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
|
+
address 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 = IAuthorization(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.getRelease()) {
|
100
|
+
revert ErrorInstanceAdminReleaseMismatch();
|
101
|
+
}
|
102
|
+
|
103
|
+
// add instance authorization
|
104
|
+
_createRoles(_instanceAuthorization);
|
105
|
+
_createModuleTargetsWithRoles();
|
106
|
+
_createTargetAuthorizations(_instanceAuthorization);
|
107
|
+
}
|
108
|
+
|
109
|
+
|
110
|
+
/// @dev Initializes the authorization for the specified component.
|
111
|
+
/// Important: The component MUST be registered.
|
112
|
+
function initializeComponentAuthorization(
|
113
|
+
IInstanceLinkedComponent component
|
114
|
+
)
|
115
|
+
external
|
116
|
+
{
|
117
|
+
_checkTargetIsReadyForAuthorization(address(component));
|
118
|
+
|
119
|
+
// get authorization specification
|
120
|
+
IAuthorization authorization = component.getAuthorization();
|
121
|
+
|
122
|
+
// create roles
|
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
|
+
FunctionInfo[] memory functions = new FunctionInfo[](3);
|
139
|
+
functions[0] = toFunction(TokenHandler.collectTokens.selector, "collectTokens");
|
140
|
+
functions[1] = toFunction(TokenHandler.collectTokensToThreeRecipients.selector, "collectTokensToThreeRecipients");
|
141
|
+
functions[2] = toFunction(TokenHandler.distributeTokens.selector, "distributeTokens");
|
142
|
+
|
143
|
+
// FIXME: make this a bit nicer and work with IAuthorization. Use a specific role, not public - access to TokenHandler must be restricted
|
144
|
+
_authorizeTargetFunctions(
|
145
|
+
address(component.getTokenHandler()),
|
146
|
+
getPublicRole(),
|
147
|
+
functions);
|
148
|
+
|
149
|
+
_grantRoleToAccount(
|
150
|
+
authorization.getTargetRole(
|
151
|
+
authorization.getMainTarget()),
|
152
|
+
address(component));
|
153
|
+
|
154
|
+
_createTargetAuthorizations(authorization);
|
155
|
+
}
|
156
|
+
|
157
|
+
/// @dev Creates a custom role
|
158
|
+
// TODO implement
|
159
|
+
// function createRole()
|
160
|
+
// external
|
161
|
+
// restricted()
|
162
|
+
// {
|
163
|
+
|
164
|
+
// }
|
165
|
+
|
166
|
+
/// @dev Grants the provided role to the specified account
|
167
|
+
function grantRole(
|
168
|
+
RoleId roleId,
|
169
|
+
address account)
|
170
|
+
external
|
171
|
+
restricted()
|
172
|
+
{
|
173
|
+
_grantRoleToAccount(roleId, account);
|
174
|
+
}
|
175
|
+
|
176
|
+
/// @dev Returns the instance authorization specification used to set up this instance admin.
|
177
|
+
function getInstanceAuthorization()
|
178
|
+
external
|
179
|
+
view
|
180
|
+
returns (IAuthorization instanceAuthorizaion)
|
181
|
+
{
|
182
|
+
return _instanceAuthorization;
|
183
|
+
}
|
184
|
+
|
185
|
+
|
186
|
+
function _createRoles(IAuthorization authorization)
|
187
|
+
internal
|
188
|
+
{
|
189
|
+
RoleId[] memory roles = authorization.getRoles();
|
190
|
+
RoleId roleId;
|
191
|
+
RoleInfo memory roleInfo;
|
192
|
+
|
193
|
+
for(uint256 i = 0; i < roles.length; i++) {
|
194
|
+
roleId = roles[i];
|
195
|
+
|
196
|
+
if (!roleExists(roleId)) {
|
197
|
+
_createRole(
|
198
|
+
roleId,
|
199
|
+
authorization.getRoleInfo(roleId));
|
200
|
+
}
|
201
|
+
}
|
202
|
+
}
|
203
|
+
|
204
|
+
|
205
|
+
function _createTargetAuthorizations(IAuthorization authorization)
|
206
|
+
internal
|
207
|
+
{
|
208
|
+
Str[] memory targets = authorization.getTargets();
|
209
|
+
Str target;
|
210
|
+
|
211
|
+
for(uint256 i = 0; i < targets.length; i++) {
|
212
|
+
target = targets[i];
|
213
|
+
RoleId[] memory authorizedRoles = authorization.getAuthorizedRoles(target);
|
214
|
+
RoleId authorizedRole;
|
215
|
+
|
216
|
+
for(uint256 j = 0; j < authorizedRoles.length; j++) {
|
217
|
+
authorizedRole = authorizedRoles[j];
|
218
|
+
|
219
|
+
_authorizeTargetFunctions(
|
220
|
+
getTargetForName(target),
|
221
|
+
authorizedRole,
|
222
|
+
authorization.getAuthorizedFunctions(
|
223
|
+
target,
|
224
|
+
authorizedRole));
|
225
|
+
}
|
226
|
+
}
|
227
|
+
}
|
228
|
+
|
229
|
+
function _checkAndCreateTargetWithRole(
|
230
|
+
address target,
|
231
|
+
string memory targetName
|
232
|
+
)
|
233
|
+
internal
|
234
|
+
{
|
235
|
+
// check that target name is defined in authorization specification
|
236
|
+
Str name = StrLib.toStr(targetName);
|
237
|
+
if (!_instanceAuthorization.targetExists(name)) {
|
238
|
+
revert ErrorInstanceAdminExpectedTargetMissing(targetName);
|
239
|
+
}
|
240
|
+
|
241
|
+
// create named target
|
242
|
+
_createTarget(
|
243
|
+
target,
|
244
|
+
targetName,
|
245
|
+
false, // check authority TODO check normal targets, don't check service targets (they share authority with release admin)
|
246
|
+
false);
|
247
|
+
|
248
|
+
// assign target role if defined
|
249
|
+
RoleId targetRoleId = _instanceAuthorization.getTargetRole(name);
|
250
|
+
if (targetRoleId != RoleIdLib.zero()) {
|
251
|
+
_grantRoleToAccount(targetRoleId, target);
|
252
|
+
}
|
253
|
+
}
|
254
|
+
|
255
|
+
function _createModuleTargetsWithRoles()
|
256
|
+
internal
|
257
|
+
{
|
258
|
+
// create module targets
|
259
|
+
_checkAndCreateTargetWithRole(address(_instance), INSTANCE_TARGET_NAME);
|
260
|
+
_checkAndCreateTargetWithRole(address(_instance.getInstanceStore()), INSTANCE_STORE_TARGET_NAME);
|
261
|
+
_checkAndCreateTargetWithRole(address(_instance.getInstanceAdmin()), INSTANCE_ADMIN_TARGET_NAME);
|
262
|
+
_checkAndCreateTargetWithRole(address(_instance.getBundleSet()), BUNDLE_SET_TARGET_NAME);
|
263
|
+
_checkAndCreateTargetWithRole(address(_instance.getRiskSet()), RISK_SET_TAGET_NAME);
|
264
|
+
|
265
|
+
// create targets for services that need to access the module targets
|
266
|
+
ObjectType[] memory serviceDomains = _instanceAuthorization.getServiceDomains();
|
267
|
+
VersionPart release = _instanceAuthorization.getRelease();
|
268
|
+
ObjectType serviceDomain;
|
269
|
+
|
270
|
+
for (uint256 i = 0; i < serviceDomains.length; i++) {
|
271
|
+
serviceDomain = serviceDomains[i];
|
272
|
+
|
273
|
+
_checkAndCreateTargetWithRole(
|
274
|
+
_registry.getServiceAddress(serviceDomain, release),
|
275
|
+
_instanceAuthorization.getServiceTarget(serviceDomain).toString());
|
276
|
+
}
|
277
|
+
}
|
278
|
+
}
|