@etherisc/gif-next 0.0.2-a105567-464 → 0.0.2-a221fa7-461
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 +30 -2
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +1253 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +1206 -0
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +358 -0
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.json +10 -0
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +1032 -0
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +258 -0
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.json +290 -0
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +148 -0
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +390 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +190 -0
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +1548 -0
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +410 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +57 -239
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +317 -95
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +97 -57
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +104 -136
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +158 -16
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +4 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +703 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +64 -84
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +152 -45
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +78 -146
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1214 -280
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +601 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +227 -62
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +221 -106
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +52 -48
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +260 -137
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +0 -53
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +182 -0
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +181 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.json +2 -2
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +1185 -0
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +418 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +52 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +802 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +675 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +1093 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +1034 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +730 -0
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +1496 -0
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +410 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +95 -58
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +53 -41
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +13 -0
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +30 -206
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +28 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +37 -314
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +77 -41
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +42 -38
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +72 -35
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +47 -35
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +1318 -0
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +410 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +112 -67
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +67 -51
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +13 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +13 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +13 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +13 -0
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +36 -46
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/product/IProductService.sol/IProductService.json +13 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +90 -45
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +56 -40
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +98 -61
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +60 -48
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +43 -164
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +54 -25
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +38 -30
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +50 -59
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +13 -183
- 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 +101 -104
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1506 -167
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +50 -13
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +37 -25
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +164 -0
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1159 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +214 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +22 -4
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +11 -11
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +242 -77
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +80 -56
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +13 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +4 -4
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +117 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +36 -4
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +11 -15
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +0 -5
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -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 +13 -0
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +43 -64
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +15 -99
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +4 -65
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +4 -0
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +306 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +6 -6
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +6 -6
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +8 -8
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -2
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +13 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +6 -6
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +114 -117
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +215 -70
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +102 -44
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +179 -182
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +164 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +43 -43
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +223 -21
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +264 -134
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +41 -45
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +771 -216
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +95 -18
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +68 -4
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +2 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +4 -4
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +4 -4
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +12 -12
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +28 -4
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +149 -2
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +4 -4
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +4 -4
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +4 -4
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +219 -6
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +26 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
- package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +17 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/MathLib.json +2 -2
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +21 -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 +617 -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 +591 -0
- package/contracts/authorization/AccessManagerCloneable.sol +16 -0
- package/contracts/authorization/Authorization.sol +218 -0
- package/contracts/authorization/IAccess.sol +48 -0
- package/contracts/authorization/IAccessAdmin.sol +136 -0
- package/contracts/authorization/IAuthorization.sol +54 -0
- package/contracts/authorization/IModuleAuthorization.sol +21 -0
- package/contracts/authorization/IServiceAuthorization.sol +38 -0
- package/contracts/authorization/ModuleAuthorization.sol +78 -0
- package/contracts/authorization/ServiceAuthorization.sol +90 -0
- package/contracts/distribution/BasicDistribution.sol +138 -0
- package/contracts/distribution/BasicDistributionAuthorization.sol +47 -0
- package/contracts/distribution/Distribution.sol +144 -110
- package/contracts/distribution/DistributionService.sol +80 -26
- package/contracts/distribution/DistributionServiceManager.sol +2 -5
- package/contracts/distribution/IDistributionComponent.sol +25 -39
- package/contracts/distribution/IDistributionService.sol +18 -1
- package/contracts/instance/{BundleManager.sol → BundleSet.sol} +23 -23
- package/contracts/instance/IInstance.sol +20 -13
- package/contracts/instance/IInstanceService.sol +34 -23
- package/contracts/instance/Instance.sol +108 -89
- package/contracts/instance/InstanceAdmin.sol +202 -267
- package/contracts/instance/InstanceAuthorizationV3.sol +204 -0
- package/contracts/instance/InstanceReader.sol +49 -9
- package/contracts/instance/InstanceService.sol +159 -78
- package/contracts/instance/InstanceServiceManager.sol +2 -6
- package/contracts/instance/InstanceStore.sol +38 -22
- package/contracts/instance/base/BalanceStore.sol +11 -6
- package/contracts/instance/base/Cloneable.sol +2 -25
- package/contracts/instance/base/ObjectCounter.sol +21 -0
- package/contracts/instance/base/ObjectLifecycle.sol +106 -0
- package/contracts/instance/base/{ObjectManager.sol → ObjectSet.sol} +11 -14
- package/contracts/instance/module/IComponents.sol +0 -1
- package/contracts/oracle/BasicOracle.sol +48 -0
- package/contracts/oracle/BasicOracleAuthorization.sol +46 -0
- package/contracts/oracle/IOracle.sol +36 -0
- package/contracts/oracle/IOracleComponent.sol +33 -0
- package/contracts/oracle/IOracleService.sol +65 -0
- package/contracts/oracle/Oracle.sol +166 -0
- package/contracts/oracle/OracleService.sol +278 -0
- package/contracts/oracle/OracleServiceManager.sol +39 -0
- package/contracts/pool/BasicPool.sol +164 -0
- package/contracts/pool/BasicPoolAuthorization.sol +52 -0
- package/contracts/pool/BundleService.sol +32 -44
- package/contracts/pool/BundleServiceManager.sol +2 -5
- package/contracts/pool/IPoolComponent.sol +0 -61
- package/contracts/pool/IPoolService.sol +3 -0
- package/contracts/pool/Pool.sol +143 -131
- package/contracts/pool/PoolService.sol +45 -33
- package/contracts/pool/PoolServiceManager.sol +2 -5
- package/contracts/product/ApplicationService.sol +17 -41
- package/contracts/product/ApplicationServiceManager.sol +2 -2
- package/contracts/product/BasicProduct.sol +82 -0
- package/contracts/product/BasicProductAuthorization.sol +43 -0
- package/contracts/product/ClaimService.sol +16 -37
- package/contracts/product/ClaimServiceManager.sol +2 -2
- package/contracts/product/IClaimService.sol +6 -0
- package/contracts/product/IProductComponent.sol +7 -9
- package/contracts/product/PolicyService.sol +7 -5
- package/contracts/product/PolicyServiceManager.sol +2 -5
- package/contracts/product/PricingService.sol +5 -6
- package/contracts/product/PricingServiceManager.sol +2 -5
- package/contracts/product/Product.sol +103 -88
- package/contracts/product/ProductService.sol +12 -37
- package/contracts/product/ProductServiceManager.sol +2 -5
- package/contracts/registry/ChainNft.sol +1 -0
- package/contracts/registry/IRegistry.sol +26 -18
- package/contracts/registry/IRegistryService.sol +6 -6
- package/contracts/registry/Registry.sol +86 -95
- package/contracts/registry/RegistryAdmin.sol +283 -155
- package/contracts/registry/RegistryService.sol +9 -23
- package/contracts/registry/RegistryServiceManager.sol +2 -7
- package/contracts/registry/ReleaseLifecycle.sol +27 -0
- package/contracts/registry/ReleaseRegistry.sol +487 -0
- package/contracts/registry/ServiceAuthorizationV3.sol +200 -0
- package/contracts/registry/TokenRegistry.sol +9 -52
- package/contracts/shared/Component.sol +19 -25
- package/contracts/shared/ComponentService.sol +94 -68
- package/contracts/shared/ComponentServiceManager.sol +2 -2
- package/contracts/shared/ComponentVerifyingService.sol +13 -7
- package/contracts/shared/IComponent.sol +3 -7
- package/contracts/shared/IComponentService.sol +21 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +10 -0
- package/contracts/shared/IKeyValueStore.sol +2 -1
- package/contracts/shared/ILifecycle.sol +1 -2
- package/contracts/shared/IService.sol +8 -1
- package/contracts/shared/InstanceLinkedComponent.sol +47 -19
- package/contracts/shared/KeyValueStore.sol +7 -6
- package/contracts/shared/Lifecycle.sol +16 -60
- package/contracts/shared/{NftIdSetManager.sol → NftIdSet.sol} +1 -1
- package/contracts/shared/Service.sol +27 -22
- package/contracts/staking/IStaking.sol +41 -26
- package/contracts/staking/IStakingService.sol +42 -44
- package/contracts/staking/StakeManagerLib.sol +101 -26
- package/contracts/staking/Staking.sol +144 -126
- package/contracts/staking/StakingLifecycle.sol +23 -0
- package/contracts/staking/StakingManager.sol +2 -6
- package/contracts/staking/StakingReader.sol +73 -36
- package/contracts/staking/StakingService.sol +121 -86
- package/contracts/staking/StakingServiceManager.sol +2 -3
- package/contracts/staking/StakingStore.sol +401 -127
- package/contracts/staking/TargetManagerLib.sol +28 -0
- package/contracts/type/Amount.sol +15 -1
- package/contracts/type/NftId.sol +8 -8
- package/contracts/type/ObjectType.sol +171 -69
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/type/RoleId.sol +103 -72
- package/contracts/type/Seconds.sol +10 -0
- package/contracts/type/Selector.sol +102 -0
- package/contracts/type/StateId.sol +12 -0
- package/contracts/type/String.sol +53 -0
- package/contracts/type/Timestamp.sol +6 -2
- package/contracts/type/UFixed.sol +6 -0
- package/contracts/type/Version.sol +3 -1
- package/contracts/{shared → upgradeability}/ProxyManager.sol +3 -4
- package/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol +1 -3
- package/package.json +8 -5
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +0 -4
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +0 -778
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +0 -204
- 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/registry/ReleaseManager.sol/ReleaseManager.dbg.json +0 -4
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +0 -1292
- 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/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +0 -1193
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +0 -1715
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +0 -1728
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +0 -1806
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +0 -1824
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +0 -4
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +0 -1562
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +0 -4
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +0 -1600
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +0 -4
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +0 -4
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +0 -306
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +0 -4
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -617
- 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/artifacts/contracts/staking/IStakingManager.sol/IStakingManager.dbg.json +0 -4
- package/artifacts/contracts/staking/IStakingManager.sol/IStakingManager.json +0 -37
- package/artifacts/contracts/staking/IStakingStore.sol/IStakingStore.dbg.json +0 -4
- package/artifacts/contracts/staking/IStakingStore.sol/IStakingStore.json +0 -357
- package/contracts/instance/InstanceAuthorizationsLib.sol +0 -349
- package/contracts/registry/ReleaseManager.sol +0 -599
- package/contracts/registry/ServiceAuthorizationsLib.sol +0 -173
- package/contracts/shared/AccessManagerCustom.sol +0 -736
- package/contracts/shared/AccessManagerExtended.sol +0 -470
- package/contracts/shared/AccessManagerExtendedInitializeable.sol +0 -13
- package/contracts/shared/AccessManagerExtendedWithDisable.sol +0 -137
- package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +0 -14
- package/contracts/shared/IAccessManagerExtended.sol +0 -74
- package/contracts/shared/IAccessManagerExtendedWithDisable.sol +0 -18
- package/contracts/staking/IStakingManager.sol +0 -15
- package/contracts/staking/IStakingStore.sol +0 -130
- /package/contracts/{shared → upgradeability}/IVersionable.sol +0 -0
- /package/contracts/{shared → upgradeability}/Versionable.sol +0 -0
@@ -0,0 +1,278 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {ComponentVerifyingService} from "../shared/ComponentVerifyingService.sol";
|
5
|
+
import {IComponent} from "../shared/IComponent.sol";
|
6
|
+
import {IInstance} from "../instance/IInstance.sol";
|
7
|
+
import {IInstanceService} from "../instance/IInstanceService.sol";
|
8
|
+
import {InstanceReader} from "../instance/InstanceReader.sol";
|
9
|
+
import {IOracle} from "./IOracle.sol";
|
10
|
+
import {IOracleComponent} from "./IOracleComponent.sol";
|
11
|
+
import {IOracleService} from "./IOracleService.sol";
|
12
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
13
|
+
import {NftId} from "../type/NftId.sol";
|
14
|
+
import {ObjectType, COMPONENT, ORACLE, INSTANCE} from "../type/ObjectType.sol";
|
15
|
+
import {RequestId} from "../type/RequestId.sol";
|
16
|
+
import {StateId, ACTIVE, KEEP_STATE, FULFILLED, FAILED, CANCELLED} from "../type/StateId.sol";
|
17
|
+
import {Timestamp, TimestampLib} from "../type/Timestamp.sol";
|
18
|
+
|
19
|
+
|
20
|
+
contract OracleService is
|
21
|
+
ComponentVerifyingService,
|
22
|
+
IOracleService
|
23
|
+
{
|
24
|
+
|
25
|
+
function _initialize(
|
26
|
+
address owner,
|
27
|
+
bytes memory data
|
28
|
+
)
|
29
|
+
internal
|
30
|
+
initializer
|
31
|
+
virtual override
|
32
|
+
{
|
33
|
+
address initialOwner;
|
34
|
+
address registryAddress;
|
35
|
+
(registryAddress, initialOwner) = abi.decode(data, (address, address));
|
36
|
+
initializeService(registryAddress, address(0), owner);
|
37
|
+
registerInterface(type(IOracleService).interfaceId);
|
38
|
+
}
|
39
|
+
|
40
|
+
function request(
|
41
|
+
NftId oracleNftId,
|
42
|
+
bytes calldata requestData,
|
43
|
+
Timestamp expiryAt,
|
44
|
+
string calldata callbackMethodName
|
45
|
+
)
|
46
|
+
external
|
47
|
+
virtual
|
48
|
+
// restricted() // add authz
|
49
|
+
returns (
|
50
|
+
RequestId requestId
|
51
|
+
)
|
52
|
+
{
|
53
|
+
(
|
54
|
+
NftId componentNftId,
|
55
|
+
IRegistry.ObjectInfo memory componentInfo,
|
56
|
+
IInstance instance
|
57
|
+
) = _getAndVerifyActiveComponent(COMPONENT());
|
58
|
+
|
59
|
+
// oracleNftId exists and is active oracle
|
60
|
+
(
|
61
|
+
IRegistry.ObjectInfo memory oracleInfo,
|
62
|
+
) = _getAndVerifyComponentInfo(
|
63
|
+
oracleNftId,
|
64
|
+
ORACLE(),
|
65
|
+
true); // only active
|
66
|
+
|
67
|
+
// check that requester and oracle share same instance
|
68
|
+
if (componentInfo.parentNftId != oracleInfo.parentNftId) {
|
69
|
+
revert ErrorOracleServiceInstanceMismatch(componentInfo.parentNftId, oracleInfo.parentNftId);
|
70
|
+
}
|
71
|
+
|
72
|
+
// check expiriyAt >= now
|
73
|
+
if (expiryAt < TimestampLib.blockTimestamp()) {
|
74
|
+
revert ErrorOracleServiceExpiryInThePast(TimestampLib.blockTimestamp(), expiryAt);
|
75
|
+
}
|
76
|
+
|
77
|
+
// check callbackMethodName.length > 0
|
78
|
+
if (bytes(callbackMethodName).length == 0) {
|
79
|
+
revert ErrorOracleServiceCallbackMethodNameEmpty();
|
80
|
+
}
|
81
|
+
|
82
|
+
// create request info
|
83
|
+
IOracle.RequestInfo memory request = IOracle.RequestInfo({
|
84
|
+
requesterNftId: componentNftId,
|
85
|
+
callbackMethodName: callbackMethodName,
|
86
|
+
oracleNftId: oracleNftId,
|
87
|
+
requestData: requestData,
|
88
|
+
responseData: "",
|
89
|
+
respondedAt: TimestampLib.zero(),
|
90
|
+
expiredAt: expiryAt,
|
91
|
+
isCancelled: false
|
92
|
+
});
|
93
|
+
|
94
|
+
// store request with instance
|
95
|
+
requestId = instance.getInstanceStore().createRequest(request);
|
96
|
+
|
97
|
+
// call oracle component
|
98
|
+
IOracleComponent(oracleInfo.objectAddress).request(
|
99
|
+
requestId,
|
100
|
+
componentNftId,
|
101
|
+
requestData,
|
102
|
+
expiryAt);
|
103
|
+
|
104
|
+
emit LogOracleServiceRequestCreated(requestId, componentNftId, oracleNftId, expiryAt);
|
105
|
+
}
|
106
|
+
|
107
|
+
|
108
|
+
/// @dev respond to oracle request by oracle compnent.
|
109
|
+
/// permissioned: only the oracle component linked to the request id may call this method
|
110
|
+
function respond(
|
111
|
+
RequestId requestId,
|
112
|
+
bytes calldata responseData
|
113
|
+
)
|
114
|
+
external
|
115
|
+
virtual
|
116
|
+
// restricted() // add authz
|
117
|
+
returns (bool success)
|
118
|
+
{
|
119
|
+
(
|
120
|
+
NftId oracleNftId,
|
121
|
+
IRegistry.ObjectInfo memory componentInfo,
|
122
|
+
IInstance instance
|
123
|
+
) = _getAndVerifyActiveComponent(ORACLE());
|
124
|
+
|
125
|
+
bool callerIsOracle = true;
|
126
|
+
IOracle.RequestInfo memory request = _checkAndGetRequestInfo(instance, requestId, oracleNftId, callerIsOracle);
|
127
|
+
request.responseData = responseData;
|
128
|
+
request.respondedAt = TimestampLib.blockTimestamp();
|
129
|
+
|
130
|
+
instance.getInstanceStore().updateRequest(
|
131
|
+
requestId, request, KEEP_STATE());
|
132
|
+
|
133
|
+
IRegistry.ObjectInfo memory requesterInfo = getRegistry().getObjectInfo(
|
134
|
+
request.requesterNftId);
|
135
|
+
|
136
|
+
string memory functionSignature = string(
|
137
|
+
abi.encodePacked(
|
138
|
+
request.callbackMethodName,
|
139
|
+
"(uint64,bytes)"
|
140
|
+
));
|
141
|
+
|
142
|
+
(success, ) = requesterInfo.objectAddress.call(
|
143
|
+
abi.encodeWithSignature(
|
144
|
+
functionSignature,
|
145
|
+
requestId,
|
146
|
+
responseData));
|
147
|
+
|
148
|
+
// check that calling requestor was successful
|
149
|
+
if (success) {
|
150
|
+
instance.getInstanceStore().updateRequestState(requestId, FULFILLED());
|
151
|
+
} else {
|
152
|
+
instance.getInstanceStore().updateRequestState(requestId, FAILED());
|
153
|
+
emit LogOracleServiceDeliveryFailed(requestId, requesterInfo.objectAddress, functionSignature);
|
154
|
+
}
|
155
|
+
|
156
|
+
emit LogOracleServiceResponseProcessed(requestId, oracleNftId);
|
157
|
+
}
|
158
|
+
|
159
|
+
|
160
|
+
function resend(RequestId requestId)
|
161
|
+
external
|
162
|
+
virtual
|
163
|
+
// restricted() // add authz
|
164
|
+
{
|
165
|
+
(
|
166
|
+
NftId requesterNftId,
|
167
|
+
IRegistry.ObjectInfo memory requesterInfo,
|
168
|
+
IInstance instance
|
169
|
+
) = _getAndVerifyActiveComponent(COMPONENT());
|
170
|
+
|
171
|
+
bool callerIsOracle = false;
|
172
|
+
IOracle.RequestInfo memory request = _checkAndGetRequestInfo(instance, requestId, requesterNftId, callerIsOracle);
|
173
|
+
|
174
|
+
// attempt to deliver response to requester
|
175
|
+
string memory functionSignature = string(
|
176
|
+
abi.encodePacked(
|
177
|
+
request.callbackMethodName,
|
178
|
+
"(uint64,bytes)"
|
179
|
+
));
|
180
|
+
|
181
|
+
(bool success, bytes memory returnData) = requesterInfo.objectAddress.call(
|
182
|
+
abi.encodeWithSignature(
|
183
|
+
functionSignature,
|
184
|
+
requestId,
|
185
|
+
request.responseData));
|
186
|
+
|
187
|
+
// check that calling requestor was successful
|
188
|
+
if (success) {
|
189
|
+
instance.getInstanceStore().updateRequestState(requestId, FULFILLED());
|
190
|
+
emit LogOracleServiceResponseResent(requestId, requesterNftId);
|
191
|
+
} else {
|
192
|
+
emit LogOracleServiceDeliveryFailed(requestId, requesterInfo.objectAddress, functionSignature);
|
193
|
+
}
|
194
|
+
}
|
195
|
+
|
196
|
+
|
197
|
+
function cancel(RequestId requestId)
|
198
|
+
external
|
199
|
+
virtual
|
200
|
+
// restricted() // add authz
|
201
|
+
{
|
202
|
+
(
|
203
|
+
NftId requesterNftId,
|
204
|
+
IRegistry.ObjectInfo memory componentInfo,
|
205
|
+
IInstance instance
|
206
|
+
) = _getAndVerifyActiveComponent(COMPONENT());
|
207
|
+
|
208
|
+
bool callerIsOracle = false;
|
209
|
+
// TODO property isCancelled and state update to CANCELLED are redundant, get rid of isCancelled
|
210
|
+
IOracle.RequestInfo memory request = _checkAndGetRequestInfo(instance, requestId, requesterNftId, callerIsOracle);
|
211
|
+
request.isCancelled = true;
|
212
|
+
|
213
|
+
instance.getInstanceStore().updateRequest(requestId, request, CANCELLED());
|
214
|
+
|
215
|
+
// call oracle component
|
216
|
+
// TODO add check that oracle is active?
|
217
|
+
address oracleAddress = getRegistry().getObjectInfo(request.oracleNftId).objectAddress;
|
218
|
+
IOracleComponent(oracleAddress).cancel(requestId);
|
219
|
+
|
220
|
+
emit LogOracleServiceRequestCancelled(requestId, requesterNftId);
|
221
|
+
}
|
222
|
+
|
223
|
+
|
224
|
+
function _checkAndGetRequestInfo(
|
225
|
+
IInstance instance,
|
226
|
+
RequestId requestId,
|
227
|
+
NftId callerNftId,
|
228
|
+
bool callerIsOracle
|
229
|
+
)
|
230
|
+
internal
|
231
|
+
virtual
|
232
|
+
view
|
233
|
+
returns (IOracle.RequestInfo memory info)
|
234
|
+
{
|
235
|
+
InstanceReader reader = instance.getInstanceReader();
|
236
|
+
StateId state = reader.getState(requestId.toKey32());
|
237
|
+
|
238
|
+
// check caller against resonsible oracle or requester
|
239
|
+
info = reader.getRequestInfo(requestId);
|
240
|
+
if (callerIsOracle) {
|
241
|
+
if (state != ACTIVE()) {
|
242
|
+
revert ErrorOracleServiceRequestStateNotActive(requestId, state);
|
243
|
+
}
|
244
|
+
|
245
|
+
if (callerNftId != info.oracleNftId) {
|
246
|
+
revert ErrorOracleServiceCallerNotResponsibleOracle(requestId, info.oracleNftId, callerNftId);
|
247
|
+
}
|
248
|
+
} else {
|
249
|
+
if (state != ACTIVE() && state != FAILED()) {
|
250
|
+
revert ErrorOracleServiceRequestStateNotActive(requestId, state);
|
251
|
+
}
|
252
|
+
if (callerNftId != info.requesterNftId) {
|
253
|
+
revert ErrorOracleServiceCallerNotRequester(requestId, info.requesterNftId, callerNftId);
|
254
|
+
}
|
255
|
+
}
|
256
|
+
|
257
|
+
// check expiry
|
258
|
+
if (info.expiredAt < TimestampLib.blockTimestamp()) {
|
259
|
+
revert ErrorOracleServiceRequestExpired(requestId, info.expiredAt);
|
260
|
+
}
|
261
|
+
}
|
262
|
+
|
263
|
+
|
264
|
+
function _getInstanceForComponent(NftId componentNftId)
|
265
|
+
internal
|
266
|
+
view
|
267
|
+
returns(IInstance instance)
|
268
|
+
{
|
269
|
+
NftId instanceNftId = getRegistry().getObjectInfo(componentNftId).parentNftId;
|
270
|
+
address instanceAddress = getRegistry().getObjectInfo(instanceNftId).objectAddress;
|
271
|
+
return IInstance(instanceAddress);
|
272
|
+
}
|
273
|
+
|
274
|
+
|
275
|
+
function _getDomain() internal pure override returns(ObjectType) {
|
276
|
+
return ORACLE();
|
277
|
+
}
|
278
|
+
}
|
@@ -0,0 +1,39 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IVersionable} from "../upgradeability/IVersionable.sol";
|
5
|
+
import {ProxyManager} from "../upgradeability/ProxyManager.sol";
|
6
|
+
import {OracleService} from "./OracleService.sol";
|
7
|
+
|
8
|
+
contract OracleServiceManager is ProxyManager {
|
9
|
+
|
10
|
+
OracleService private _oracleService;
|
11
|
+
|
12
|
+
/// @dev initializes proxy manager with service implementation and deploys instance
|
13
|
+
constructor(
|
14
|
+
address authority,
|
15
|
+
address registryAddress,
|
16
|
+
bytes32 salt
|
17
|
+
)
|
18
|
+
ProxyManager(registryAddress)
|
19
|
+
{
|
20
|
+
OracleService orclSrv = new OracleService{salt: salt}();
|
21
|
+
bytes memory data = abi.encode(registryAddress, address(this), authority);
|
22
|
+
IVersionable versionable = deployDetermenistic(
|
23
|
+
address(orclSrv),
|
24
|
+
data,
|
25
|
+
salt);
|
26
|
+
|
27
|
+
_oracleService = OracleService(address(versionable));
|
28
|
+
}
|
29
|
+
|
30
|
+
//--- view functions ----------------------------------------------------//
|
31
|
+
function getOracleService()
|
32
|
+
external
|
33
|
+
view
|
34
|
+
returns (OracleService oracleService)
|
35
|
+
{
|
36
|
+
return _oracleService;
|
37
|
+
}
|
38
|
+
|
39
|
+
}
|
@@ -0,0 +1,164 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Amount, AmountLib} from "../type/Amount.sol";
|
5
|
+
import {InstanceLinkedComponent} from "../shared/InstanceLinkedComponent.sol";
|
6
|
+
import {Fee, FeeLib} from "../type/Fee.sol";
|
7
|
+
import {IAuthorization} from "../authorization/IAuthorization.sol";
|
8
|
+
import {IBundleService} from "./IBundleService.sol";
|
9
|
+
import {IPoolComponent} from "./IPoolComponent.sol";
|
10
|
+
import {IPoolService} from "./IPoolService.sol";
|
11
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
12
|
+
import {IComponentService} from "../shared/IComponentService.sol";
|
13
|
+
import {NftId, NftIdLib} from "../type/NftId.sol";
|
14
|
+
import {BUNDLE, COMPONENT, POOL} from "../type/ObjectType.sol";
|
15
|
+
import {RoleId, PUBLIC_ROLE} from "../type/RoleId.sol";
|
16
|
+
import {Seconds} from "../type/Seconds.sol";
|
17
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
18
|
+
import {UFixed, UFixedLib} from "../type/UFixed.sol";
|
19
|
+
|
20
|
+
import {Pool} from "./Pool.sol";
|
21
|
+
|
22
|
+
abstract contract BasicPool is
|
23
|
+
Pool
|
24
|
+
{
|
25
|
+
|
26
|
+
function _initializeBasicPool(
|
27
|
+
address registry,
|
28
|
+
NftId instanceNftId,
|
29
|
+
IAuthorization authorization,
|
30
|
+
address token,
|
31
|
+
string memory name,
|
32
|
+
address initialOwner
|
33
|
+
)
|
34
|
+
internal
|
35
|
+
virtual
|
36
|
+
onlyInitializing()
|
37
|
+
{
|
38
|
+
_initializePool(
|
39
|
+
registry,
|
40
|
+
instanceNftId,
|
41
|
+
name,
|
42
|
+
token,
|
43
|
+
authorization,
|
44
|
+
false, // isInterceptingNftTransfers,
|
45
|
+
initialOwner,
|
46
|
+
"", // registryData
|
47
|
+
""); // componentData
|
48
|
+
}
|
49
|
+
|
50
|
+
function stake(
|
51
|
+
NftId bundleNftId,
|
52
|
+
Amount amount
|
53
|
+
)
|
54
|
+
public
|
55
|
+
virtual
|
56
|
+
restricted()
|
57
|
+
onlyBundleOwner(bundleNftId)
|
58
|
+
{
|
59
|
+
_stake(bundleNftId, amount);
|
60
|
+
}
|
61
|
+
|
62
|
+
|
63
|
+
function unstake(
|
64
|
+
NftId bundleNftId,
|
65
|
+
Amount amount
|
66
|
+
)
|
67
|
+
public
|
68
|
+
virtual
|
69
|
+
restricted()
|
70
|
+
onlyBundleOwner(bundleNftId)
|
71
|
+
{
|
72
|
+
_unstake(bundleNftId, amount);
|
73
|
+
}
|
74
|
+
|
75
|
+
|
76
|
+
function extend(
|
77
|
+
NftId bundleNftId,
|
78
|
+
Seconds lifetimeExtension
|
79
|
+
)
|
80
|
+
public
|
81
|
+
virtual
|
82
|
+
restricted()
|
83
|
+
onlyBundleOwner(bundleNftId)
|
84
|
+
{
|
85
|
+
_extend(bundleNftId, lifetimeExtension);
|
86
|
+
}
|
87
|
+
|
88
|
+
|
89
|
+
function lockBundle(NftId bundleNftId)
|
90
|
+
public
|
91
|
+
virtual
|
92
|
+
restricted()
|
93
|
+
onlyBundleOwner(bundleNftId)
|
94
|
+
{
|
95
|
+
_lockBundle(bundleNftId);
|
96
|
+
}
|
97
|
+
|
98
|
+
|
99
|
+
function unlockBundle(NftId bundleNftId)
|
100
|
+
public
|
101
|
+
virtual
|
102
|
+
restricted()
|
103
|
+
onlyBundleOwner(bundleNftId)
|
104
|
+
{
|
105
|
+
_unlockBundle(bundleNftId);
|
106
|
+
}
|
107
|
+
|
108
|
+
|
109
|
+
function close(NftId bundleNftId)
|
110
|
+
public
|
111
|
+
virtual
|
112
|
+
restricted()
|
113
|
+
onlyBundleOwner(bundleNftId)
|
114
|
+
{
|
115
|
+
_close(bundleNftId);
|
116
|
+
}
|
117
|
+
|
118
|
+
|
119
|
+
function setBundleFee(
|
120
|
+
NftId bundleNftId,
|
121
|
+
Fee memory fee
|
122
|
+
)
|
123
|
+
public
|
124
|
+
virtual
|
125
|
+
restricted()
|
126
|
+
onlyBundleOwner(bundleNftId)
|
127
|
+
{
|
128
|
+
_setBundleFee(bundleNftId, fee);
|
129
|
+
}
|
130
|
+
|
131
|
+
|
132
|
+
function setMaxCapitalAmount(Amount maxCapitalAmount)
|
133
|
+
public
|
134
|
+
virtual
|
135
|
+
restricted()
|
136
|
+
onlyOwner()
|
137
|
+
{
|
138
|
+
_setMaxCapitalAmount(maxCapitalAmount);
|
139
|
+
}
|
140
|
+
|
141
|
+
|
142
|
+
function setBundleOwnerRole(RoleId bundleOwnerRole)
|
143
|
+
public
|
144
|
+
virtual
|
145
|
+
restricted()
|
146
|
+
onlyOwner()
|
147
|
+
{
|
148
|
+
_setBundleOwnerRole(bundleOwnerRole);
|
149
|
+
}
|
150
|
+
|
151
|
+
|
152
|
+
function setFees(
|
153
|
+
Fee memory poolFee,
|
154
|
+
Fee memory stakingFee,
|
155
|
+
Fee memory performanceFee
|
156
|
+
)
|
157
|
+
public
|
158
|
+
virtual
|
159
|
+
restricted()
|
160
|
+
onlyOwner()
|
161
|
+
{
|
162
|
+
_setPoolFees(poolFee, stakingFee, performanceFee);
|
163
|
+
}
|
164
|
+
}
|
@@ -0,0 +1,52 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Authorization} from "../authorization/Authorization.sol";
|
5
|
+
import {BasicPool} from "./BasicPool.sol";
|
6
|
+
import {IAccess} from "../authorization/IAccess.sol";
|
7
|
+
import {IInstanceLinkedComponent} from "../shared/IInstanceLinkedComponent.sol";
|
8
|
+
import {POOL} from "../type/ObjectType.sol";
|
9
|
+
import {PUBLIC_ROLE} from "../../contracts/type/RoleId.sol";
|
10
|
+
import {RoleId} from "../type/RoleId.sol";
|
11
|
+
|
12
|
+
|
13
|
+
contract BasicPoolAuthorization
|
14
|
+
is Authorization
|
15
|
+
{
|
16
|
+
|
17
|
+
constructor(string memory poolName)
|
18
|
+
Authorization(poolName)
|
19
|
+
{}
|
20
|
+
|
21
|
+
function _setupTargets()
|
22
|
+
internal
|
23
|
+
virtual override
|
24
|
+
{
|
25
|
+
_addComponentTargetWithRole(POOL()); // basic pool target
|
26
|
+
}
|
27
|
+
|
28
|
+
|
29
|
+
function _setupTargetAuthorizations()
|
30
|
+
internal
|
31
|
+
virtual override
|
32
|
+
{
|
33
|
+
IAccess.FunctionInfo[] storage functions;
|
34
|
+
|
35
|
+
// authorize public role (open access to any account, only allows to lock target)
|
36
|
+
functions = _authorizeForTarget(getTargetName(), PUBLIC_ROLE());
|
37
|
+
_authorize(functions, BasicPool.stake.selector, "stake");
|
38
|
+
_authorize(functions, BasicPool.unstake.selector, "unstake");
|
39
|
+
_authorize(functions, BasicPool.extend.selector, "extend");
|
40
|
+
_authorize(functions, BasicPool.lockBundle.selector, "lockBundle");
|
41
|
+
_authorize(functions, BasicPool.unlockBundle.selector, "unlockBundle");
|
42
|
+
_authorize(functions, BasicPool.close.selector, "close");
|
43
|
+
_authorize(functions, BasicPool.setBundleFee.selector, "setBundleFee");
|
44
|
+
|
45
|
+
_authorize(functions, BasicPool.setMaxCapitalAmount.selector, "setMaxCapitalAmount");
|
46
|
+
_authorize(functions, BasicPool.setBundleOwnerRole.selector, "setBundleOwnerRole");
|
47
|
+
_authorize(functions, BasicPool.setFees.selector, "setFees");
|
48
|
+
|
49
|
+
_authorize(functions, IInstanceLinkedComponent.withdrawFees.selector, "withdrawFees");
|
50
|
+
}
|
51
|
+
}
|
52
|
+
|
@@ -2,36 +2,24 @@
|
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {IBundle} from "../instance/module/IBundle.sol";
|
5
|
-
import {
|
5
|
+
import {IBundleService} from "./IBundleService.sol";
|
6
6
|
import {IComponentService} from "../shared/IComponentService.sol";
|
7
7
|
import {IRegistry} from "../registry/IRegistry.sol";
|
8
|
+
import {IRegistryService} from "../registry/IRegistryService.sol";
|
8
9
|
import {IInstance} from "../instance/IInstance.sol";
|
9
10
|
import {InstanceStore} from "../instance/InstanceStore.sol";
|
10
11
|
import {IPolicy} from "../instance/module/IPolicy.sol";
|
11
12
|
|
12
|
-
import {
|
13
|
-
import {
|
13
|
+
import {Amount, AmountLib} from "../type/Amount.sol";
|
14
|
+
import {BundleSet} from "../instance/BundleSet.sol";
|
15
|
+
import {ComponentVerifyingService} from "../shared/ComponentVerifyingService.sol";
|
16
|
+
import {Fee} from "../type/Fee.sol";
|
17
|
+
import {InstanceReader} from "../instance/InstanceReader.sol";
|
14
18
|
import {NftId, NftIdLib} from "../type/NftId.sol";
|
15
19
|
import {ObjectType, COMPONENT, POOL, BUNDLE, REGISTRY} from "../type/ObjectType.sol";
|
16
|
-
import {POOL_OWNER_ROLE, RoleId} from "../type/RoleId.sol";
|
17
|
-
import {Pool} from "./Pool.sol";
|
18
|
-
|
19
|
-
import {Amount, AmountLib} from "../type/Amount.sol";
|
20
|
-
import {Fee, FeeLib} from "../type/Fee.sol";
|
21
20
|
import {StateId, ACTIVE, PAUSED, CLOSED, KEEP_STATE} from "../type/StateId.sol";
|
22
21
|
import {Seconds} from "../type/Seconds.sol";
|
23
22
|
import {TimestampLib, zeroTimestamp} from "../type/Timestamp.sol";
|
24
|
-
import {Version, VersionLib} from "../type/Version.sol";
|
25
|
-
import {Versionable} from "../shared/Versionable.sol";
|
26
|
-
|
27
|
-
import {IService} from "../shared/IService.sol";
|
28
|
-
import {Service} from "../shared/Service.sol";
|
29
|
-
import {BundleManager} from "../instance/BundleManager.sol";
|
30
|
-
import {ComponentVerifyingService} from "../shared/ComponentVerifyingService.sol";
|
31
|
-
import {IBundleService} from "./IBundleService.sol";
|
32
|
-
import {IRegistryService} from "../registry/IRegistryService.sol";
|
33
|
-
import {InstanceService} from "../instance/InstanceService.sol";
|
34
|
-
import {InstanceReader} from "../instance/InstanceReader.sol";
|
35
23
|
|
36
24
|
string constant BUNDLE_SERVICE_NAME = "BundleService";
|
37
25
|
|
@@ -68,10 +56,6 @@ contract BundleService is
|
|
68
56
|
registerInterface(type(IBundleService).interfaceId);
|
69
57
|
}
|
70
58
|
|
71
|
-
function getDomain() public pure override returns(ObjectType) {
|
72
|
-
return BUNDLE();
|
73
|
-
}
|
74
|
-
|
75
59
|
|
76
60
|
function setFee(
|
77
61
|
NftId bundleNftId,
|
@@ -143,7 +127,7 @@ contract BundleService is
|
|
143
127
|
AmountLib.zero()); // fee amount
|
144
128
|
|
145
129
|
// put bundle under bundle managemet
|
146
|
-
|
130
|
+
BundleSet bundleManager = instance.getBundleSet();
|
147
131
|
bundleManager.add(bundleNftId);
|
148
132
|
|
149
133
|
// TODO add logging
|
@@ -201,7 +185,7 @@ contract BundleService is
|
|
201
185
|
instance.getInstanceStore().updateBundleState(bundleNftId, PAUSED());
|
202
186
|
|
203
187
|
// update set of active bundles
|
204
|
-
|
188
|
+
BundleSet bundleManager = instance.getBundleSet();
|
205
189
|
bundleManager.lock(bundleNftId);
|
206
190
|
|
207
191
|
emit LogBundleServiceBundleLocked(bundleNftId);
|
@@ -218,7 +202,7 @@ contract BundleService is
|
|
218
202
|
instance.getInstanceStore().updateBundleState(bundleNftId, ACTIVE());
|
219
203
|
|
220
204
|
// update set of active bundles
|
221
|
-
|
205
|
+
BundleSet bundleManager = instance.getBundleSet();
|
222
206
|
bundleManager.unlock(bundleNftId);
|
223
207
|
|
224
208
|
emit LogBundleServiceBundleActivated(bundleNftId);
|
@@ -237,7 +221,7 @@ contract BundleService is
|
|
237
221
|
instance.getInstanceStore().updateBundleState(bundleNftId, CLOSED());
|
238
222
|
|
239
223
|
// ensure no open policies attached to bundle
|
240
|
-
|
224
|
+
BundleSet bundleManager = instance.getBundleSet();
|
241
225
|
uint256 openPolicies = bundleManager.activePolicies(bundleNftId);
|
242
226
|
if(openPolicies > 0) {
|
243
227
|
revert ErrorBundleServiceBundleWithOpenPolicies(bundleNftId, openPolicies);
|
@@ -261,22 +245,6 @@ contract BundleService is
|
|
261
245
|
instance.getInstanceStore().decreaseLocked(bundleNftId, collateralAmount);
|
262
246
|
}
|
263
247
|
|
264
|
-
/// @dev links policy to bundle
|
265
|
-
function _linkPolicy(IInstance instance, NftId policyNftId)
|
266
|
-
internal
|
267
|
-
{
|
268
|
-
InstanceReader instanceReader = instance.getInstanceReader();
|
269
|
-
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
270
|
-
|
271
|
-
// ensure policy has not yet been activated in a previous tx already
|
272
|
-
if (policyInfo.activatedAt.gtz() && policyInfo.activatedAt < TimestampLib.blockTimestamp()) {
|
273
|
-
revert BundleManager.ErrorBundleManagerPolicyAlreadyActivated(policyNftId);
|
274
|
-
}
|
275
|
-
|
276
|
-
BundleManager bundleManager = instance.getBundleManager();
|
277
|
-
bundleManager.linkPolicy(policyNftId);
|
278
|
-
}
|
279
|
-
|
280
248
|
/// @dev unlinks policy from bundle
|
281
249
|
function unlinkPolicy(
|
282
250
|
IInstance instance,
|
@@ -291,6 +259,26 @@ contract BundleService is
|
|
291
259
|
revert ErrorBundleServicePolicyNotCloseable(policyNftId);
|
292
260
|
}
|
293
261
|
|
294
|
-
instance.
|
262
|
+
instance.getBundleSet().unlinkPolicy(policyNftId);
|
263
|
+
}
|
264
|
+
|
265
|
+
/// @dev links policy to bundle
|
266
|
+
function _linkPolicy(IInstance instance, NftId policyNftId)
|
267
|
+
internal
|
268
|
+
{
|
269
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
270
|
+
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
271
|
+
|
272
|
+
// ensure policy has not yet been activated in a previous tx already
|
273
|
+
if (policyInfo.activatedAt.gtz() && policyInfo.activatedAt < TimestampLib.blockTimestamp()) {
|
274
|
+
revert BundleSet.ErrorBundleSetPolicyAlreadyActivated(policyNftId);
|
275
|
+
}
|
276
|
+
|
277
|
+
BundleSet bundleManager = instance.getBundleSet();
|
278
|
+
bundleManager.linkPolicy(policyNftId);
|
279
|
+
}
|
280
|
+
|
281
|
+
function _getDomain() internal pure override returns(ObjectType) {
|
282
|
+
return BUNDLE();
|
295
283
|
}
|
296
284
|
}
|
@@ -1,12 +1,9 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {IVersionable} from "../
|
5
|
-
import {ProxyManager} from "../
|
4
|
+
import {IVersionable} from "../upgradeability/IVersionable.sol";
|
5
|
+
import {ProxyManager} from "../upgradeability/ProxyManager.sol";
|
6
6
|
import {BundleService} from "./BundleService.sol";
|
7
|
-
import {Registry} from "../registry/Registry.sol";
|
8
|
-
import {RegistryService} from "../registry/RegistryService.sol";
|
9
|
-
import {ObjectType, REGISTRY} from "../type/ObjectType.sol";
|
10
7
|
|
11
8
|
contract BundleServiceManager is ProxyManager {
|
12
9
|
|