@etherisc/gif-next 0.0.2-f13c010-035 → 0.0.2-f15b559-661
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/accounting/AccountingService.sol/AccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +1007 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +744 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +791 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +148 -62
- 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/AccessManagerCloneable.sol/AccessManagerCloneable.json +233 -5
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +149 -21
- 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 +82 -12
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +68 -13
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +2 -2
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +108 -188
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +152 -33
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +57 -89
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +244 -190
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +82 -56
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +44 -58
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +120 -73
- 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 +101 -164
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +152 -33
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +256 -296
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +152 -33
- 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 +139 -131
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +589 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +90 -126
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +225 -162
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +589 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +638 -301
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +589 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +193 -45
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +118 -39
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +77 -20
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +163 -56
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +375 -99
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +140 -40
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +586 -215
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +104 -74
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +49 -27
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +412 -372
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +853 -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 +2 -2
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +16 -5
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +168 -0
- 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 +74 -154
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +126 -35
- 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 +44 -58
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +27 -3
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +58 -90
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +112 -81
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +69 -27
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +57 -104
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +152 -33
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +127 -331
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +53 -87
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +56 -136
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +44 -97
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +164 -217
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +57 -128
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +456 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +302 -353
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +93 -51
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +105 -63
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +45 -27
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +163 -175
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +152 -33
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +244 -179
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +74 -64
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +61 -10
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +142 -20
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +112 -56
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +27 -3
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +150 -144
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.json +37 -7
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +211 -180
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +293 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +76 -50
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +99 -76
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +60 -38
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +163 -175
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +114 -77
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +62 -24
- 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 +50 -2
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +31 -7
- package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +4 -0
- package/artifacts/contracts/registry/IRelease.sol/IRelease.json +24 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +88 -40
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +262 -220
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +69 -46
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +42 -20
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +1849 -0
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +2 -2
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +318 -52
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +6 -6
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +4 -4
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +57 -75
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +225 -439
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +74 -64
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +27 -16
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +454 -5
- 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/ContractLib.sol/ITokenRegistryHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +40 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +44 -44
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +125 -282
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +44 -58
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- 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 +120 -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 +27 -3
- 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 +57 -89
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -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 +2 -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 +118 -62
- 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 +27 -16
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +289 -112
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +484 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +70 -30
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +62 -80
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +56 -3
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +33 -33
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +134 -173
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +2 -2
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +58 -46
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +4 -4
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +101 -49
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +47 -25
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +129 -129
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +23 -23
- 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/Amount.sol/AmountLib.json +3 -3
- 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/Fee.sol/FeeLib.json +3 -3
- 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 +69 -7
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +79 -15
- 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/SelectorLib.json +21 -2
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +2 -2
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- 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/Timestamp.sol/TimestampLib.json +2 -2
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -21
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +47 -2
- 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 +18 -2
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
- package/contracts/accounting/AccountingService.sol +262 -0
- package/contracts/accounting/AccountingServiceManager.sol +38 -0
- package/contracts/accounting/IAccountingService.sol +45 -0
- package/contracts/authorization/AccessAdmin.sol +177 -84
- package/contracts/authorization/AccessManagerCloneable.sol +136 -3
- package/contracts/authorization/Authorization.sol +277 -229
- package/contracts/authorization/IAccessAdmin.sol +13 -7
- package/contracts/authorization/IAuthorization.sol +15 -1
- package/contracts/distribution/BasicDistribution.sol +13 -11
- package/contracts/distribution/BasicDistributionAuthorization.sol +22 -9
- package/contracts/distribution/Distribution.sol +42 -38
- package/contracts/distribution/DistributionService.sol +54 -51
- package/contracts/distribution/DistributionServiceManager.sol +1 -1
- package/contracts/distribution/IDistributionService.sol +19 -19
- package/contracts/examples/fire/FirePool.sol +22 -5
- package/contracts/examples/fire/FirePoolAuthorization.sol +2 -1
- package/contracts/examples/fire/FireProduct.sol +32 -10
- package/contracts/examples/fire/FireProductAuthorization.sol +2 -1
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +7 -0
- package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimplePool.sol +33 -3
- package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +51 -25
- package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
- package/contracts/instance/BundleSet.sol +42 -38
- package/contracts/instance/IInstance.sol +13 -9
- package/contracts/instance/IInstanceService.sol +9 -9
- package/contracts/instance/Instance.sol +33 -18
- package/contracts/instance/InstanceAdmin.sol +242 -84
- package/contracts/instance/InstanceAuthorizationV3.sol +50 -31
- package/contracts/instance/InstanceReader.sol +174 -32
- package/contracts/instance/InstanceService.sol +73 -82
- package/contracts/instance/InstanceServiceManager.sol +1 -1
- package/contracts/instance/InstanceStore.sol +13 -2
- package/contracts/instance/RiskSet.sol +118 -0
- package/contracts/instance/base/ObjectCounter.sol +1 -2
- package/contracts/instance/base/ObjectLifecycle.sol +4 -2
- package/contracts/instance/base/ObjectSet.sol +31 -33
- package/contracts/instance/base/ObjectSetHelperLib.sol +30 -0
- package/contracts/instance/module/IComponents.sol +4 -4
- package/contracts/instance/module/IDistribution.sol +2 -1
- package/contracts/instance/module/IPolicy.sol +2 -1
- package/contracts/instance/module/IRisk.sol +3 -0
- package/contracts/oracle/BasicOracleAuthorization.sol +3 -12
- package/contracts/oracle/Oracle.sol +1 -1
- package/contracts/oracle/OracleService.sol +92 -73
- package/contracts/oracle/OracleServiceManager.sol +1 -1
- package/contracts/pool/BasicPool.sol +24 -3
- package/contracts/pool/BasicPoolAuthorization.sol +27 -8
- package/contracts/pool/BundleService.sol +47 -145
- package/contracts/pool/BundleServiceManager.sol +1 -1
- package/contracts/pool/IBundleService.sol +15 -43
- package/contracts/pool/IPoolComponent.sol +1 -7
- package/contracts/pool/IPoolService.sol +58 -60
- package/contracts/pool/Pool.sol +106 -96
- package/contracts/pool/PoolLib.sol +216 -0
- package/contracts/pool/PoolService.sol +427 -214
- package/contracts/pool/PoolServiceManager.sol +1 -1
- package/contracts/product/ApplicationService.sol +15 -15
- package/contracts/product/ApplicationServiceManager.sol +1 -1
- package/contracts/product/BasicProduct.sol +9 -11
- package/contracts/product/BasicProductAuthorization.sol +24 -10
- package/contracts/product/ClaimService.sol +157 -137
- package/contracts/product/ClaimServiceManager.sol +1 -1
- package/contracts/product/IApplicationService.sol +5 -2
- package/contracts/product/IClaimService.sol +14 -2
- package/contracts/product/IPolicyService.sol +26 -11
- package/contracts/product/IProductComponent.sol +4 -1
- package/contracts/product/IRiskService.sol +5 -8
- package/contracts/product/PolicyService.sol +244 -253
- package/contracts/product/PolicyServiceLib.sol +65 -0
- package/contracts/product/PolicyServiceManager.sol +1 -1
- package/contracts/product/PricingService.sol +23 -19
- package/contracts/product/PricingServiceManager.sol +3 -3
- package/contracts/product/Product.sol +66 -52
- package/contracts/product/RiskService.sol +79 -31
- package/contracts/product/RiskServiceManager.sol +1 -1
- package/contracts/registry/ChainNft.sol +4 -2
- package/contracts/registry/IRegistry.sol +10 -15
- package/contracts/registry/IRelease.sol +26 -0
- package/contracts/registry/Registry.sol +16 -3
- package/contracts/registry/RegistryAdmin.sol +132 -226
- package/contracts/registry/RegistryService.sol +3 -3
- package/contracts/registry/RegistryServiceManager.sol +1 -1
- package/contracts/registry/ReleaseAdmin.sol +245 -0
- package/contracts/registry/ReleaseLifecycle.sol +2 -0
- package/contracts/registry/ReleaseRegistry.sol +129 -119
- package/contracts/registry/ServiceAuthorizationV3.sol +93 -40
- package/contracts/registry/TokenRegistry.sol +6 -8
- package/contracts/shared/Component.sol +61 -105
- package/contracts/shared/ComponentService.sol +301 -295
- package/contracts/shared/ComponentServiceManager.sol +1 -1
- package/contracts/shared/ComponentVerifyingService.sol +16 -14
- package/contracts/shared/ContractLib.sol +224 -9
- package/contracts/shared/IComponent.sol +4 -17
- package/contracts/shared/IComponentService.sol +16 -25
- package/contracts/shared/IInstanceLinkedComponent.sol +0 -11
- package/contracts/shared/IRegisterable.sol +15 -4
- package/contracts/shared/IService.sol +3 -5
- package/contracts/shared/InstanceLinkedComponent.sol +4 -20
- package/contracts/shared/NftOwnable.sol +4 -4
- package/contracts/shared/PolicyHolder.sol +1 -1
- package/contracts/shared/Registerable.sol +44 -20
- package/contracts/shared/RegistryLinked.sol +7 -13
- package/contracts/shared/Service.sol +8 -27
- package/contracts/shared/TokenHandler.sol +263 -105
- package/contracts/shared/TokenHandlerDeployerLib.sol +10 -2
- package/contracts/staking/IStaking.sol +5 -8
- package/contracts/staking/IStakingService.sol +8 -0
- package/contracts/staking/StakeManagerLib.sol +1 -1
- package/contracts/staking/Staking.sol +62 -33
- package/contracts/staking/StakingReader.sol +1 -1
- package/contracts/staking/StakingService.sol +35 -12
- package/contracts/staking/StakingServiceManager.sol +5 -4
- 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 +48 -21
- package/contracts/type/RiskId.sol +26 -8
- package/contracts/type/RoleId.sol +24 -4
- package/contracts/type/Selector.sol +5 -0
- package/contracts/type/Timestamp.sol +0 -5
- package/contracts/type/UFixed.sol +9 -119
- package/contracts/type/Version.sol +15 -5
- package/contracts/upgradeability/ProxyManager.sol +1 -1
- package/package.json +3 -3
- package/artifacts/contracts/authorization/ReleaseAccessManager.sol/ReleaseAccessManager.dbg.json +0 -4
- package/artifacts/contracts/authorization/ReleaseAccessManager.sol/ReleaseAccessManager.json +0 -1196
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +0 -129
- package/artifacts/contracts/shared/ComponentServiceHelperLib.sol/ComponentServiceHelperLib.dbg.json +0 -4
- package/artifacts/contracts/shared/ComponentServiceHelperLib.sol/ComponentServiceHelperLib.json +0 -206
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.json +0 -16
- package/contracts/authorization/ReleaseAccessManager.sol +0 -38
- package/contracts/instance/module/IAccess.sol +0 -46
- package/contracts/shared/ComponentServiceHelperLib.sol +0 -118
@@ -2,22 +2,26 @@
|
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {AccessAdmin} from "../authorization/AccessAdmin.sol";
|
5
|
+
import {AccessManagerCloneable} from "../authorization/AccessManagerCloneable.sol";
|
5
6
|
import {IAccess} from "../authorization/IAccess.sol";
|
7
|
+
import {IComponent} from "../shared/IComponent.sol";
|
6
8
|
import {IRegistry} from "./IRegistry.sol";
|
7
9
|
import {IService} from "../shared/IService.sol";
|
8
10
|
import {IServiceAuthorization} from "../authorization/IServiceAuthorization.sol";
|
9
11
|
import {IStaking} from "../staking/IStaking.sol";
|
10
|
-
import {ObjectType, ObjectTypeLib, ALL, REGISTRY, STAKING, POOL, RELEASE} from "../type/ObjectType.sol";
|
12
|
+
import {ObjectType, ObjectTypeLib, ALL, COMPONENT, REGISTRY, STAKING, POOL, RELEASE} from "../type/ObjectType.sol";
|
11
13
|
import {ReleaseRegistry} from "./ReleaseRegistry.sol";
|
12
14
|
import {RoleId, RoleIdLib, ADMIN_ROLE, GIF_MANAGER_ROLE, GIF_ADMIN_ROLE, PUBLIC_ROLE} from "../type/RoleId.sol";
|
15
|
+
import {Staking} from "../staking/Staking.sol";
|
13
16
|
import {StakingStore} from "../staking/StakingStore.sol";
|
14
17
|
import {TokenHandler} from "../shared/TokenHandler.sol";
|
15
18
|
import {TokenRegistry} from "./TokenRegistry.sol";
|
16
|
-
import {VersionPart} from "../type/Version.sol";
|
19
|
+
import {VersionPart, VersionPartLib} from "../type/Version.sol";
|
17
20
|
|
18
21
|
/*
|
19
22
|
1) GIF_MANAGER_ROLE
|
20
23
|
- can have arbitrary number of members
|
24
|
+
- responsible for release preparation
|
21
25
|
- responsible for services registrations
|
22
26
|
- responsible for token registration and activation
|
23
27
|
|
@@ -25,28 +29,38 @@ import {VersionPart} from "../type/Version.sol";
|
|
25
29
|
- admin of GIF_MANAGER_ROLE
|
26
30
|
- MUST have 1 member at any time
|
27
31
|
- granted/revoked ONLY in transferAdminRole() -> consider lock out situations!!!
|
28
|
-
- responsible for creation and
|
32
|
+
- responsible for creation, activation and locking/unlocking of releases
|
29
33
|
*/
|
34
|
+
|
35
|
+
/// @dev The RegistryAdmin contract implements the central authorization for the GIF core contracts.
|
36
|
+
/// These are the release independent registry and staking contracts and their respective helper contracts.
|
37
|
+
/// The RegistryAdmin also manages the access from service contracts to the GIF core contracts
|
30
38
|
contract RegistryAdmin is
|
31
39
|
AccessAdmin
|
32
40
|
{
|
41
|
+
/// @dev gif core roles
|
33
42
|
string public constant GIF_ADMIN_ROLE_NAME = "GifAdminRole";
|
34
43
|
string public constant GIF_MANAGER_ROLE_NAME = "GifManagerRole";
|
35
|
-
string public constant POOL_SERVICE_ROLE_NAME = "PoolServiceRole";
|
36
44
|
string public constant RELEASE_REGISTRY_ROLE_NAME = "ReleaseRegistryRole";
|
45
|
+
string public constant STAKING_ROLE_NAME = "StakingRole";
|
46
|
+
|
47
|
+
/// @dev gif roles for external contracts
|
37
48
|
string public constant REGISTRY_SERVICE_ROLE_NAME = "RegistryServiceRole";
|
49
|
+
string public constant COMPONENT_SERVICE_ROLE_NAME = "ComponentServiceRole";
|
50
|
+
string public constant POOL_SERVICE_ROLE_NAME = "PoolServiceRole";
|
38
51
|
string public constant STAKING_SERVICE_ROLE_NAME = "StakingServiceRole";
|
39
|
-
string public constant STAKING_ROLE_NAME = "StakingRole";
|
40
52
|
|
53
|
+
/// @dev gif core targets
|
54
|
+
string public constant REGISTRY_ADMIN_TARGET_NAME = "RegistryAdmin";
|
41
55
|
string public constant REGISTRY_TARGET_NAME = "Registry";
|
42
56
|
string public constant RELEASE_REGISTRY_TARGET_NAME = "ReleaseRegistry";
|
43
|
-
string public constant TOKEN_REGISTRY_TARGET_NAME = "TokenRegistry";
|
44
57
|
string public constant STAKING_TARGET_NAME = "Staking";
|
58
|
+
string public constant STAKING_TH_TARGET_NAME = "StakingTH";
|
45
59
|
string public constant STAKING_STORE_TARGET_NAME = "StakingStore";
|
60
|
+
string public constant TOKEN_REGISTRY_TARGET_NAME = "TokenRegistry";
|
61
|
+
string public constant TOKEN_HANDLER_TARGET_NAME = "TokenHandler";
|
46
62
|
|
47
63
|
uint8 public constant MAX_NUM_RELEASES = 99;
|
48
|
-
// TODO consider deleting this
|
49
|
-
mapping(address service => VersionPart majorVersion) private _ServiceRelease;
|
50
64
|
|
51
65
|
address internal _registry;
|
52
66
|
address private _releaseRegistry;
|
@@ -54,17 +68,26 @@ contract RegistryAdmin is
|
|
54
68
|
address private _staking;
|
55
69
|
address private _stakingStore;
|
56
70
|
|
57
|
-
constructor()
|
71
|
+
constructor() {
|
72
|
+
initialize(new AccessManagerCloneable());
|
73
|
+
}
|
58
74
|
|
59
75
|
function completeSetup(
|
60
76
|
IRegistry registry,
|
61
77
|
address gifAdmin,
|
62
78
|
address gifManager
|
63
79
|
)
|
64
|
-
|
65
|
-
|
80
|
+
public
|
81
|
+
virtual
|
82
|
+
reinitializer(type(uint8).max)
|
66
83
|
onlyDeployer()
|
67
84
|
{
|
85
|
+
AccessManagerCloneable accessManager = AccessManagerCloneable(authority());
|
86
|
+
accessManager.completeSetup(
|
87
|
+
address(registry),
|
88
|
+
VersionPartLib.toVersionPart(type(uint8).max),
|
89
|
+
false);
|
90
|
+
|
68
91
|
_registry = address(registry);
|
69
92
|
_releaseRegistry = registry.getReleaseRegistryAddress();
|
70
93
|
_tokenRegistry = registry.getTokenRegistryAddress();
|
@@ -72,48 +95,22 @@ contract RegistryAdmin is
|
|
72
95
|
_stakingStore = address(
|
73
96
|
IStaking(_staking).getStakingStore());
|
74
97
|
|
75
|
-
|
76
|
-
_createTarget(_tokenRegistry, TOKEN_REGISTRY_TARGET_NAME, true, false);
|
98
|
+
_createTargets();
|
77
99
|
|
78
100
|
_setupGifAdminRole(gifAdmin);
|
79
101
|
_setupGifManagerRole(gifManager);
|
80
102
|
|
81
|
-
|
82
|
-
|
83
|
-
_setupStaking();
|
84
|
-
}
|
85
|
-
|
86
|
-
|
87
|
-
/// @dev Sets up authorizaion for specified service.
|
88
|
-
/// For all authorized services its authorized functions are enabled.
|
89
|
-
/// Permissioned function: Access is restricted to release manager.
|
90
|
-
function authorizeService(
|
91
|
-
IServiceAuthorization serviceAuthorization,
|
92
|
-
IService service,
|
93
|
-
ObjectType serviceDomain,
|
94
|
-
VersionPart releaseVersion
|
95
|
-
)
|
96
|
-
external
|
97
|
-
restricted()
|
98
|
-
{
|
99
|
-
_createServiceTargetAndRole(service, serviceDomain, releaseVersion);
|
100
|
-
_authorizeServiceFunctions(serviceAuthorization, service, serviceDomain, releaseVersion);
|
103
|
+
_setupRegistryRoles();
|
104
|
+
_setupStakingRoles();
|
101
105
|
}
|
102
106
|
|
103
|
-
function
|
104
|
-
IService service,
|
105
|
-
ObjectType domain,
|
106
|
-
VersionPart version
|
107
|
-
)
|
107
|
+
/*function transferAdmin(address to)
|
108
108
|
external
|
109
|
-
restricted
|
109
|
+
restricted // only with GIF_ADMIN_ROLE or nft owner
|
110
110
|
{
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
version),
|
115
|
-
address(service));
|
116
|
-
}
|
111
|
+
_accessManager.revoke(GIF_ADMIN_ROLE, );
|
112
|
+
_accesssManager.grant(GIF_ADMIN_ROLE, to, 0);
|
113
|
+
}*/
|
117
114
|
|
118
115
|
function grantServiceRoleForAllVersions(IService service, ObjectType domain)
|
119
116
|
external
|
@@ -124,21 +121,6 @@ contract RegistryAdmin is
|
|
124
121
|
address(service));
|
125
122
|
}
|
126
123
|
|
127
|
-
function setServiceLocked(IService service, bool locked)
|
128
|
-
external
|
129
|
-
restricted()
|
130
|
-
{
|
131
|
-
_setTargetClosed(address(service), locked);
|
132
|
-
}
|
133
|
-
|
134
|
-
/*function transferAdmin(address to)
|
135
|
-
external
|
136
|
-
restricted // only with GIF_ADMIN_ROLE or nft owner
|
137
|
-
{
|
138
|
-
_accessManager.revoke(GIF_ADMIN_ROLE, );
|
139
|
-
_accesssManager.grant(GIF_ADMIN_ROLE, to, 0);
|
140
|
-
}*/
|
141
|
-
|
142
124
|
//--- view functions ----------------------------------------------------//
|
143
125
|
|
144
126
|
function getGifAdminRole() external view returns (RoleId) {
|
@@ -149,96 +131,29 @@ contract RegistryAdmin is
|
|
149
131
|
return GIF_MANAGER_ROLE();
|
150
132
|
}
|
151
133
|
|
152
|
-
//--- private functions
|
134
|
+
//--- private initialization functions -------------------------------------------//
|
153
135
|
|
154
|
-
function
|
155
|
-
|
156
|
-
|
157
|
-
VersionPart releaseVersion
|
158
|
-
)
|
159
|
-
private
|
136
|
+
function _createTargets()
|
137
|
+
private
|
138
|
+
onlyInitializing()
|
160
139
|
{
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
// create service target
|
165
|
-
string memory serviceTargetName = ObjectTypeLib.toVersionedName(
|
166
|
-
baseName, "Service", versionInt);
|
167
|
-
|
168
|
-
_createTarget(
|
169
|
-
address(service),
|
170
|
-
serviceTargetName,
|
171
|
-
true,
|
172
|
-
false);
|
173
|
-
|
174
|
-
_setTargetClosed(address(service), true);
|
175
|
-
|
176
|
-
// create service role
|
177
|
-
RoleId serviceRoleId = RoleIdLib.roleForTypeAndVersion(
|
178
|
-
serviceDomain,
|
179
|
-
releaseVersion);
|
180
|
-
|
181
|
-
_createRole(
|
182
|
-
serviceRoleId,
|
183
|
-
toRole({
|
184
|
-
adminRoleId: ADMIN_ROLE(),
|
185
|
-
roleType: RoleType.Contract,
|
186
|
-
maxMemberCount: 1,
|
187
|
-
name: ObjectTypeLib.toVersionedName(
|
188
|
-
baseName,
|
189
|
-
"ServiceRole",
|
190
|
-
versionInt)}));
|
191
|
-
|
192
|
-
_grantRoleToAccount(
|
193
|
-
serviceRoleId,
|
194
|
-
address(service));
|
195
|
-
}
|
196
|
-
|
140
|
+
IStaking staking = IStaking(_staking);
|
141
|
+
address tokenHandler = address(staking.getTokenHandler());
|
197
142
|
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
|
205
|
-
{
|
206
|
-
ObjectType authorizedDomain;
|
207
|
-
RoleId authorizedRoleId;
|
208
|
-
|
209
|
-
ObjectType[] memory authorizedDomains = serviceAuthorization.getAuthorizedDomains(serviceDomain);
|
210
|
-
|
211
|
-
for (uint256 i = 0; i < authorizedDomains.length; i++) {
|
212
|
-
authorizedDomain = authorizedDomains[i];
|
213
|
-
|
214
|
-
// derive authorized role from authorized domain
|
215
|
-
if (authorizedDomain == ALL()) {
|
216
|
-
authorizedRoleId = PUBLIC_ROLE();
|
217
|
-
} else {
|
218
|
-
authorizedRoleId = RoleIdLib.roleForTypeAndVersion(
|
219
|
-
authorizedDomain,
|
220
|
-
releaseVersion);
|
221
|
-
}
|
222
|
-
|
223
|
-
// get authorized functions for authorized domain
|
224
|
-
IAccess.FunctionInfo[] memory authorizatedFunctions = serviceAuthorization.getAuthorizedFunctions(
|
225
|
-
serviceDomain,
|
226
|
-
authorizedDomain);
|
227
|
-
|
228
|
-
_authorizeTargetFunctions(
|
229
|
-
address(service),
|
230
|
-
authorizedRoleId,
|
231
|
-
authorizatedFunctions);
|
232
|
-
}
|
143
|
+
_createTarget(address(this), REGISTRY_ADMIN_TARGET_NAME, false, false);
|
144
|
+
_createTarget(_registry, REGISTRY_TARGET_NAME, true, false);
|
145
|
+
_createTarget(_releaseRegistry, RELEASE_REGISTRY_TARGET_NAME, true, false);
|
146
|
+
_createTarget(_staking, STAKING_TARGET_NAME, true, false);
|
147
|
+
_createTarget(_stakingStore, STAKING_STORE_TARGET_NAME, true, false);
|
148
|
+
_createTarget(_tokenRegistry, TOKEN_REGISTRY_TARGET_NAME, true, false);
|
149
|
+
_createTarget(tokenHandler, TOKEN_HANDLER_TARGET_NAME, true, false);
|
233
150
|
}
|
234
151
|
|
235
|
-
//--- private initialization functions -------------------------------------------//
|
236
|
-
|
237
152
|
function _setupGifAdminRole(address gifAdmin)
|
238
153
|
private
|
239
154
|
onlyInitializing()
|
240
155
|
{
|
241
|
-
|
156
|
+
// create gif admin role
|
242
157
|
_createRole(
|
243
158
|
GIF_ADMIN_ROLE(),
|
244
159
|
toRole({
|
@@ -247,18 +162,17 @@ contract RegistryAdmin is
|
|
247
162
|
maxMemberCount: 2, // TODO decide on max member count
|
248
163
|
name: GIF_ADMIN_ROLE_NAME}));
|
249
164
|
|
250
|
-
// for
|
165
|
+
// grant permissions to the gif admin role for registry contract
|
251
166
|
FunctionInfo[] memory functions;
|
252
167
|
functions = new FunctionInfo[](1);
|
253
168
|
functions[0] = toFunction(IRegistry.registerRegistry.selector, "registerRegistry");
|
254
169
|
_authorizeTargetFunctions(_registry, GIF_ADMIN_ROLE(), functions);
|
255
170
|
|
256
|
-
// for
|
257
|
-
functions = new FunctionInfo[](
|
171
|
+
// grant permissions to the gif admin role for release registry contract
|
172
|
+
functions = new FunctionInfo[](3);
|
258
173
|
functions[0] = toFunction(ReleaseRegistry.createNextRelease.selector, "createNextRelease");
|
259
174
|
functions[1] = toFunction(ReleaseRegistry.activateNextRelease.selector, "activateNextRelease");
|
260
|
-
functions[2] = toFunction(ReleaseRegistry.
|
261
|
-
functions[3] = toFunction(ReleaseRegistry.unpauseRelease.selector, "unpauseRelease");
|
175
|
+
functions[2] = toFunction(ReleaseRegistry.setActive.selector, "setActive");
|
262
176
|
_authorizeTargetFunctions(_releaseRegistry, GIF_ADMIN_ROLE(), functions);
|
263
177
|
|
264
178
|
_grantRoleToAccount(GIF_ADMIN_ROLE(), gifAdmin);
|
@@ -268,16 +182,16 @@ contract RegistryAdmin is
|
|
268
182
|
private
|
269
183
|
onlyInitializing()
|
270
184
|
{
|
271
|
-
|
185
|
+
// create gif manager role
|
272
186
|
_createRole(
|
273
187
|
GIF_MANAGER_ROLE(),
|
274
188
|
toRole({
|
275
189
|
adminRoleId: ADMIN_ROLE(),
|
276
190
|
roleType: RoleType.Gif,
|
277
|
-
maxMemberCount: 1,
|
191
|
+
maxMemberCount: 1, // TODO decide on max member count
|
278
192
|
name: GIF_MANAGER_ROLE_NAME}));
|
279
193
|
|
280
|
-
// for
|
194
|
+
// grant permissions to the gif manager role for token registry contract
|
281
195
|
FunctionInfo[] memory functions;
|
282
196
|
functions = new FunctionInfo[](5);
|
283
197
|
functions[0] = toFunction(TokenRegistry.registerToken.selector, "registerToken");
|
@@ -288,7 +202,7 @@ contract RegistryAdmin is
|
|
288
202
|
functions[4] = toFunction(TokenRegistry.setActiveWithVersionCheck.selector, "setActiveWithVersionCheck");
|
289
203
|
_authorizeTargetFunctions(_tokenRegistry, GIF_MANAGER_ROLE(), functions);
|
290
204
|
|
291
|
-
// for
|
205
|
+
// grant permissions to the gif manager role for release registry contract
|
292
206
|
functions = new FunctionInfo[](2);
|
293
207
|
functions[0] = toFunction(ReleaseRegistry.prepareNextRelease.selector, "prepareNextRelease");
|
294
208
|
functions[1] = toFunction(ReleaseRegistry.registerService.selector, "registerService");
|
@@ -297,14 +211,12 @@ contract RegistryAdmin is
|
|
297
211
|
_grantRoleToAccount(GIF_MANAGER_ROLE(), gifManager);
|
298
212
|
}
|
299
213
|
|
300
|
-
|
301
|
-
|
302
|
-
private
|
214
|
+
function _setupRegistryRoles()
|
215
|
+
private
|
303
216
|
onlyInitializing()
|
304
217
|
{
|
305
|
-
|
306
|
-
|
307
|
-
|
218
|
+
// TODO use RELEASE_REGISTRY_ROLE instead
|
219
|
+
// create and grant release registry role
|
308
220
|
RoleId releaseRegistryRoleId = RoleIdLib.roleForType(RELEASE());
|
309
221
|
_createRole(
|
310
222
|
releaseRegistryRoleId,
|
@@ -313,27 +225,20 @@ contract RegistryAdmin is
|
|
313
225
|
roleType: RoleType.Contract,
|
314
226
|
maxMemberCount: 1,
|
315
227
|
name: RELEASE_REGISTRY_ROLE_NAME}));
|
228
|
+
_grantRoleToAccount(releaseRegistryRoleId, _releaseRegistry);
|
316
229
|
|
230
|
+
// grant permissions to the release registry role for release admin contract
|
317
231
|
FunctionInfo[] memory functions;
|
318
|
-
functions = new FunctionInfo[](
|
319
|
-
functions[0] = toFunction(RegistryAdmin.
|
320
|
-
functions[1] = toFunction(RegistryAdmin.grantServiceRoleForAllVersions.selector, "grantServiceRoleForAllVersions");
|
321
|
-
functions[2] = toFunction(RegistryAdmin.grantServiceRole.selector, "grantServiceRole");
|
322
|
-
functions[3] = toFunction(RegistryAdmin.setServiceLocked.selector, "setServiceLocked");
|
232
|
+
functions = new FunctionInfo[](1);
|
233
|
+
functions[0] = toFunction(RegistryAdmin.grantServiceRoleForAllVersions.selector, "grantServiceRoleForAllVersions");
|
323
234
|
_authorizeTargetFunctions(address(this), releaseRegistryRoleId, functions);
|
324
235
|
|
325
|
-
|
326
|
-
|
327
|
-
|
328
|
-
|
329
|
-
function _setupRegistry()
|
330
|
-
internal
|
331
|
-
virtual
|
332
|
-
onlyInitializing()
|
333
|
-
{
|
334
|
-
_createTarget(_registry, REGISTRY_TARGET_NAME, true, false);
|
236
|
+
// grant permissions to the release registry role for registry contract
|
237
|
+
functions = new FunctionInfo[](1);
|
238
|
+
functions[0] = toFunction(IRegistry.registerService.selector, "registerService");
|
239
|
+
_authorizeTargetFunctions(_registry, releaseRegistryRoleId, functions);
|
335
240
|
|
336
|
-
//
|
241
|
+
// create registry service role
|
337
242
|
RoleId registryServiceRoleId = RoleIdLib.roleForTypeAndAllVersions(REGISTRY());
|
338
243
|
_createRole(
|
339
244
|
registryServiceRoleId,
|
@@ -343,29 +248,56 @@ contract RegistryAdmin is
|
|
343
248
|
maxMemberCount: MAX_NUM_RELEASES,
|
344
249
|
name: REGISTRY_SERVICE_ROLE_NAME}));
|
345
250
|
|
346
|
-
//
|
347
|
-
FunctionInfo[] memory functions;
|
251
|
+
// grant permissions to the registry service role for registry contract
|
348
252
|
functions = new FunctionInfo[](2);
|
349
253
|
functions[0] = toFunction(IRegistry.register.selector, "register");
|
350
254
|
functions[1] = toFunction(IRegistry.registerWithCustomType.selector, "registerWithCustomType");
|
351
255
|
_authorizeTargetFunctions(_registry, registryServiceRoleId, functions);
|
352
|
-
|
353
|
-
// authorize release registry
|
354
|
-
RoleId releaseRegistryRoleId = RoleIdLib.roleForType(RELEASE());
|
355
|
-
functions = new FunctionInfo[](1);
|
356
|
-
functions[0] = toFunction(IRegistry.registerService.selector, "registerService");
|
357
|
-
_authorizeTargetFunctions(_registry, releaseRegistryRoleId, functions);
|
358
256
|
}
|
359
257
|
|
360
258
|
|
361
|
-
function
|
259
|
+
function _setupStakingRoles()
|
362
260
|
private
|
363
261
|
onlyInitializing()
|
364
262
|
{
|
365
|
-
|
366
|
-
|
263
|
+
// create and grant staking contract role
|
264
|
+
RoleId stakingRoleId = RoleIdLib.roleForType(STAKING());
|
265
|
+
_createRole(
|
266
|
+
stakingRoleId,
|
267
|
+
toRole({
|
268
|
+
adminRoleId: ADMIN_ROLE(),
|
269
|
+
roleType: RoleType.Contract,
|
270
|
+
maxMemberCount: 1,
|
271
|
+
name: STAKING_ROLE_NAME}));
|
272
|
+
_grantRoleToAccount(stakingRoleId, _staking);
|
367
273
|
|
368
|
-
// staking
|
274
|
+
// grant permissions to the staking role for staking store contract
|
275
|
+
FunctionInfo[] memory functions;
|
276
|
+
functions = new FunctionInfo[](14);
|
277
|
+
functions[0] = toFunction(StakingStore.setStakingRate.selector, "setStakingRate");
|
278
|
+
functions[1] = toFunction(StakingStore.createTarget.selector, "createTarget");
|
279
|
+
functions[2] = toFunction(StakingStore.updateTarget.selector, "updateTarget");
|
280
|
+
functions[3] = toFunction(StakingStore.increaseReserves.selector, "increaseReserves");
|
281
|
+
functions[4] = toFunction(StakingStore.decreaseReserves.selector, "decreaseReserves");
|
282
|
+
functions[5] = toFunction(StakingStore.increaseTotalValueLocked.selector, "increaseTotalValueLocked");
|
283
|
+
functions[6] = toFunction(StakingStore.decreaseTotalValueLocked.selector, "decreaseTotalValueLocked");
|
284
|
+
functions[7] = toFunction(StakingStore.create.selector, "create");
|
285
|
+
functions[8] = toFunction(StakingStore.update.selector, "update");
|
286
|
+
functions[9] = toFunction(StakingStore.increaseStake.selector, "increaseStake");
|
287
|
+
functions[10] = toFunction(StakingStore.restakeRewards.selector, "restakeRewards");
|
288
|
+
functions[11] = toFunction(StakingStore.updateRewards.selector, "updateRewards");
|
289
|
+
functions[12] = toFunction(StakingStore.claimUpTo.selector, "claimUpTo");
|
290
|
+
functions[13] = toFunction(StakingStore.unstakeUpTo.selector, "unstakeUpTo");
|
291
|
+
_authorizeTargetFunctions(_stakingStore, stakingRoleId, functions);
|
292
|
+
|
293
|
+
// grant permissions to the staking role for token handler contract
|
294
|
+
IStaking staking = IStaking(_staking);
|
295
|
+
functions = new FunctionInfo[](2);
|
296
|
+
functions[0] = toFunction(TokenHandler.pullToken.selector, "pullToken");
|
297
|
+
functions[1] = toFunction(TokenHandler.pushToken.selector, "pushToken");
|
298
|
+
_authorizeTargetFunctions(address(staking.getTokenHandler()), stakingRoleId, functions);
|
299
|
+
|
300
|
+
// create staking service role
|
369
301
|
RoleId stakingServiceRoleId = RoleIdLib.roleForTypeAndAllVersions(STAKING());
|
370
302
|
_createRole(
|
371
303
|
stakingServiceRoleId,
|
@@ -375,8 +307,8 @@ contract RegistryAdmin is
|
|
375
307
|
maxMemberCount: MAX_NUM_RELEASES,
|
376
308
|
name: STAKING_SERVICE_ROLE_NAME}));
|
377
309
|
|
378
|
-
|
379
|
-
functions = new FunctionInfo[](
|
310
|
+
// grant permissions to the staking service role for staking contract
|
311
|
+
functions = new FunctionInfo[](11);
|
380
312
|
functions[0] = toFunction(IStaking.registerTarget.selector, "registerTarget");
|
381
313
|
functions[1] = toFunction(IStaking.setLockingPeriod.selector, "setLockingPeriod");
|
382
314
|
functions[2] = toFunction(IStaking.setRewardRate.selector, "setRewardRate");
|
@@ -388,11 +320,17 @@ contract RegistryAdmin is
|
|
388
320
|
functions[8] = toFunction(IStaking.restake.selector, "restake");
|
389
321
|
functions[9] = toFunction(IStaking.updateRewards.selector, "updateRewards");
|
390
322
|
functions[10] = toFunction(IStaking.claimRewards.selector, "claimRewards");
|
391
|
-
functions[11] = toFunction(IStaking.collectDipAmount.selector, "collectDipAmount");
|
392
|
-
functions[12] = toFunction(IStaking.transferDipAmount.selector, "transferDipAmount");
|
393
323
|
_authorizeTargetFunctions(_staking, stakingServiceRoleId, functions);
|
394
324
|
|
395
|
-
// staking
|
325
|
+
// grant permissions to the staking service role for staking token handler
|
326
|
+
functions = new FunctionInfo[](3);
|
327
|
+
functions[0] = toFunction(TokenHandler.approve.selector, "approve");
|
328
|
+
functions[1] = toFunction(TokenHandler.pullToken.selector, "pullToken");
|
329
|
+
functions[2] = toFunction(TokenHandler.pushToken.selector, "pushToken");
|
330
|
+
_authorizeTargetFunctions(
|
331
|
+
address(IComponent(_staking).getTokenHandler()), stakingServiceRoleId, functions);
|
332
|
+
|
333
|
+
// create pool service role
|
396
334
|
RoleId poolServiceRoleId = RoleIdLib.roleForTypeAndAllVersions(POOL());
|
397
335
|
_createRole(
|
398
336
|
poolServiceRoleId,
|
@@ -402,47 +340,15 @@ contract RegistryAdmin is
|
|
402
340
|
maxMemberCount: MAX_NUM_RELEASES,
|
403
341
|
name: POOL_SERVICE_ROLE_NAME}));
|
404
342
|
|
405
|
-
// staking
|
343
|
+
// grant permissions to the pool service role for staking contract
|
406
344
|
functions = new FunctionInfo[](2);
|
407
345
|
functions[0] = toFunction(IStaking.increaseTotalValueLocked.selector, "increaseTotalValueLocked");
|
408
346
|
functions[1] = toFunction(IStaking.decreaseTotalValueLocked.selector, "decreaseTotalValueLocked");
|
409
347
|
_authorizeTargetFunctions(_staking, poolServiceRoleId, functions);
|
410
348
|
|
411
|
-
//
|
412
|
-
|
413
|
-
|
414
|
-
|
415
|
-
toRole({
|
416
|
-
adminRoleId: ADMIN_ROLE(),
|
417
|
-
roleType: RoleType.Contract,
|
418
|
-
maxMemberCount: 1,
|
419
|
-
name: STAKING_ROLE_NAME}));
|
420
|
-
|
421
|
-
functions = new FunctionInfo[](14);
|
422
|
-
functions[0] = toFunction(StakingStore.setStakingRate.selector, "setStakingRate");
|
423
|
-
functions[1] = toFunction(StakingStore.createTarget.selector, "createTarget");
|
424
|
-
functions[2] = toFunction(StakingStore.updateTarget.selector, "updateTarget");
|
425
|
-
functions[3] = toFunction(StakingStore.increaseReserves.selector, "increaseReserves");
|
426
|
-
functions[4] = toFunction(StakingStore.decreaseReserves.selector, "decreaseReserves");
|
427
|
-
functions[5] = toFunction(StakingStore.increaseTotalValueLocked.selector, "increaseTotalValueLocked");
|
428
|
-
functions[6] = toFunction(StakingStore.decreaseTotalValueLocked.selector, "decreaseTotalValueLocked");
|
429
|
-
functions[7] = toFunction(StakingStore.create.selector, "create");
|
430
|
-
functions[8] = toFunction(StakingStore.update.selector, "update");
|
431
|
-
functions[9] = toFunction(StakingStore.increaseStake.selector, "increaseStake");
|
432
|
-
functions[10] = toFunction(StakingStore.restakeRewards.selector, "restakeRewards");
|
433
|
-
functions[11] = toFunction(StakingStore.updateRewards.selector, "updateRewards");
|
434
|
-
functions[12] = toFunction(StakingStore.claimUpTo.selector, "claimUpTo");
|
435
|
-
functions[13] = toFunction(StakingStore.unstakeUpTo.selector, "unstakeUpTo");
|
436
|
-
_authorizeTargetFunctions(_stakingStore, stakingRoleId, functions);
|
437
|
-
|
438
|
-
_grantRoleToAccount(stakingRoleId, _staking);
|
439
|
-
|
440
|
-
// grant token handler authorizations
|
441
|
-
IStaking staking = IStaking(_staking);
|
442
|
-
functions = new FunctionInfo[](2);
|
443
|
-
functions[0] = toFunction(TokenHandler.collectTokens.selector, "collectTokens");
|
444
|
-
functions[1] = toFunction(TokenHandler.distributeTokens.selector, "distributeTokens");
|
445
|
-
|
446
|
-
_authorizeTargetFunctions(address(staking.getTokenHandler()), stakingRoleId, functions);
|
349
|
+
// grant permissions to public role for staking contract
|
350
|
+
functions = new FunctionInfo[](1);
|
351
|
+
functions[0] = toFunction(Staking.approveTokenHandler.selector, "approveTokenHandler");
|
352
|
+
_authorizeTargetFunctions(_staking, PUBLIC_ROLE(), functions);
|
447
353
|
}
|
448
354
|
}
|
@@ -33,11 +33,11 @@ contract RegistryService is
|
|
33
33
|
initializer()
|
34
34
|
{
|
35
35
|
(
|
36
|
-
address
|
37
|
-
address
|
36
|
+
address authority,
|
37
|
+
address registry
|
38
38
|
) = abi.decode(data, (address, address));
|
39
39
|
|
40
|
-
|
40
|
+
__Service_init(authority, registry, owner);
|
41
41
|
_registerInterface(type(IRegistryService).interfaceId);
|
42
42
|
}
|
43
43
|
|
@@ -31,7 +31,7 @@ contract RegistryServiceManager is
|
|
31
31
|
}
|
32
32
|
|
33
33
|
RegistryService srv = new RegistryService{ salt: salt }();
|
34
|
-
bytes memory data = abi.encode(
|
34
|
+
bytes memory data = abi.encode(authority, registry);
|
35
35
|
IVersionable versionable = initialize(
|
36
36
|
registry,
|
37
37
|
address(srv),
|