@etherisc/gif-next 0.0.2-8bdd2eb-413 → 0.0.2-8d9d4d6-542
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/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +1502 -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 +1168 -0
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.json +110 -0
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +129 -0
- package/artifacts/contracts/authorization/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
- package/artifacts/contracts/authorization/InstanceAdmin.sol/InstanceAdmin.json +1639 -0
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +134 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +171 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +108 -79
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +48 -40
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +13 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +32 -101
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +58 -65
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +120 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +72 -79
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +22 -22
- package/artifacts/contracts/instance/InstanceAdminNew.sol/InstanceAdminNew.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAdminNew.sol/InstanceAdminNew.json +1676 -0
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +289 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +70 -46
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +192 -56
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +201 -34
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +41 -17
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +248 -108
- 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/ObjectManager.sol/ObjectManager.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +2 -71
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +10 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +759 -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 +1146 -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/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +78 -49
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +33 -25
- 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/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +13 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +62 -41
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +25 -21
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +66 -37
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +27 -19
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +106 -69
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +47 -35
- 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/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 +84 -47
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +36 -24
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +92 -63
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +40 -32
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- 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 +21 -13
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +13 -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 +19 -19
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1678 -153
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +51 -14
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +20 -8
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +99 -154
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +195 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +2 -2
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +42 -10
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +42 -10
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +52 -20
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +52 -20
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +107 -71
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +44 -36
- 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/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +1 -1
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +20 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- 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/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/IVersionable.sol/IVersionable.dbg.json +1 -1
- 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/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +8 -8
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +6 -6
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.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/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +2 -2
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +2 -2
- 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/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +49 -7
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +44 -28
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +44 -84
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +23 -39
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +6 -6
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +92 -73
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +33 -41
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +186 -114
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +18 -18
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +2 -2
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +2 -2
- 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 +125 -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 +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 +2 -2
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +114 -4
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- 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/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/contracts/authorization/AccessAdmin.sol +749 -0
- package/contracts/authorization/IAccess.sol +43 -0
- package/contracts/authorization/IAccessAdmin.sol +130 -0
- package/contracts/authorization/IModuleAuthorization.sol +27 -0
- package/contracts/authorization/IServiceAuthorization.sol +35 -0
- package/contracts/authorization/InstanceAdmin.sol +108 -0
- package/contracts/authorization/ModuleAuthorization.sol +116 -0
- package/contracts/authorization/ServiceAuthorization.sol +86 -0
- package/contracts/distribution/DistributionService.sol +3 -4
- package/contracts/instance/IInstance.sol +14 -6
- package/contracts/instance/IInstanceService.sol +24 -8
- package/contracts/instance/Instance.sol +63 -39
- package/contracts/instance/InstanceAdminNew.sol +74 -0
- package/contracts/instance/InstanceAuthorizationV3.sol +176 -0
- package/contracts/instance/InstanceAuthorizationsLib.sol +31 -3
- package/contracts/instance/InstanceReader.sol +29 -2
- package/contracts/instance/InstanceService.sol +85 -8
- package/contracts/instance/InstanceStore.sol +29 -20
- 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/ObjectManager.sol +1 -3
- package/contracts/oracle/IOracle.sol +20 -0
- package/contracts/oracle/IOracleComponent.sol +32 -0
- package/contracts/oracle/IOracleService.sol +65 -0
- package/contracts/oracle/Oracle.sol +145 -0
- package/contracts/oracle/OracleService.sol +278 -0
- package/contracts/oracle/OracleServiceManager.sol +42 -0
- package/contracts/pool/BundleService.sol +19 -19
- package/contracts/pool/PoolService.sol +6 -7
- package/contracts/product/ApplicationService.sol +5 -5
- package/contracts/product/ClaimService.sol +5 -5
- package/contracts/product/IClaimService.sol +6 -0
- package/contracts/product/PolicyService.sol +5 -5
- package/contracts/product/PricingService.sol +5 -6
- package/contracts/product/ProductService.sol +5 -5
- package/contracts/registry/IRegistry.sol +1 -1
- package/contracts/registry/Registry.sol +7 -1
- package/contracts/registry/RegistryAdmin.sol +236 -148
- package/contracts/registry/RegistryService.sol +5 -5
- package/contracts/registry/RegistryServiceManager.sol +0 -5
- package/contracts/registry/ReleaseManager.sol +102 -172
- package/contracts/registry/ServiceAuthorizationV3.sol +200 -0
- package/contracts/shared/AccessManagerCustom.sol +6 -1
- package/contracts/shared/AccessManagerExtended.sol +12 -1
- package/contracts/shared/Component.sol +3 -0
- package/contracts/shared/ComponentService.sol +30 -9
- package/contracts/shared/ComponentVerifyingService.sol +13 -7
- package/contracts/shared/IComponentService.sol +11 -0
- package/contracts/shared/IService.sol +7 -0
- package/contracts/shared/Lifecycle.sol +11 -2
- package/contracts/shared/Service.sol +27 -21
- package/contracts/staking/IStakingService.sol +11 -7
- package/contracts/staking/StakeManagerLib.sol +52 -0
- package/contracts/staking/Staking.sol +58 -96
- package/contracts/staking/StakingService.sol +61 -56
- package/contracts/staking/StakingServiceManager.sol +0 -1
- package/contracts/staking/StakingStore.sol +79 -38
- package/contracts/type/ObjectType.sol +162 -67
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/type/RoleId.sol +77 -19
- 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/package.json +3 -3
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +0 -4
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +0 -137
- package/contracts/registry/ServiceAuthorizationsLib.sol +0 -173
@@ -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,42 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IVersionable} from "../shared/IVersionable.sol";
|
5
|
+
import {ProxyManager} from "../shared/ProxyManager.sol";
|
6
|
+
import {OracleService} from "./OracleService.sol";
|
7
|
+
import {Registry} from "../registry/Registry.sol";
|
8
|
+
import {RegistryService} from "../registry/RegistryService.sol";
|
9
|
+
import {REGISTRY} from "../type/ObjectType.sol";
|
10
|
+
|
11
|
+
contract OracleServiceManager is ProxyManager {
|
12
|
+
|
13
|
+
OracleService private _oracleService;
|
14
|
+
|
15
|
+
/// @dev initializes proxy manager with service implementation and deploys instance
|
16
|
+
constructor(
|
17
|
+
address authority,
|
18
|
+
address registryAddress,
|
19
|
+
bytes32 salt
|
20
|
+
)
|
21
|
+
ProxyManager(registryAddress)
|
22
|
+
{
|
23
|
+
OracleService orclSrv = new OracleService{salt: salt}();
|
24
|
+
bytes memory data = abi.encode(registryAddress, address(this), authority);
|
25
|
+
IVersionable versionable = deployDetermenistic(
|
26
|
+
address(orclSrv),
|
27
|
+
data,
|
28
|
+
salt);
|
29
|
+
|
30
|
+
_oracleService = OracleService(address(versionable));
|
31
|
+
}
|
32
|
+
|
33
|
+
//--- view functions ----------------------------------------------------//
|
34
|
+
function getOracleService()
|
35
|
+
external
|
36
|
+
view
|
37
|
+
returns (OracleService oracleService)
|
38
|
+
{
|
39
|
+
return _oracleService;
|
40
|
+
}
|
41
|
+
|
42
|
+
}
|
@@ -68,10 +68,6 @@ contract BundleService is
|
|
68
68
|
registerInterface(type(IBundleService).interfaceId);
|
69
69
|
}
|
70
70
|
|
71
|
-
function getDomain() public pure override returns(ObjectType) {
|
72
|
-
return BUNDLE();
|
73
|
-
}
|
74
|
-
|
75
71
|
|
76
72
|
function setFee(
|
77
73
|
NftId bundleNftId,
|
@@ -261,6 +257,23 @@ contract BundleService is
|
|
261
257
|
instance.getInstanceStore().decreaseLocked(bundleNftId, collateralAmount);
|
262
258
|
}
|
263
259
|
|
260
|
+
/// @dev unlinks policy from bundle
|
261
|
+
function unlinkPolicy(
|
262
|
+
IInstance instance,
|
263
|
+
NftId policyNftId
|
264
|
+
)
|
265
|
+
external
|
266
|
+
virtual
|
267
|
+
restricted
|
268
|
+
{
|
269
|
+
// ensure policy is closeable
|
270
|
+
if (!instance.getInstanceReader().policyIsCloseable(policyNftId)) {
|
271
|
+
revert ErrorBundleServicePolicyNotCloseable(policyNftId);
|
272
|
+
}
|
273
|
+
|
274
|
+
instance.getBundleManager().unlinkPolicy(policyNftId);
|
275
|
+
}
|
276
|
+
|
264
277
|
/// @dev links policy to bundle
|
265
278
|
function _linkPolicy(IInstance instance, NftId policyNftId)
|
266
279
|
internal
|
@@ -277,20 +290,7 @@ contract BundleService is
|
|
277
290
|
bundleManager.linkPolicy(policyNftId);
|
278
291
|
}
|
279
292
|
|
280
|
-
|
281
|
-
|
282
|
-
IInstance instance,
|
283
|
-
NftId policyNftId
|
284
|
-
)
|
285
|
-
external
|
286
|
-
virtual
|
287
|
-
restricted
|
288
|
-
{
|
289
|
-
// ensure policy is closeable
|
290
|
-
if (!instance.getInstanceReader().policyIsCloseable(policyNftId)) {
|
291
|
-
revert ErrorBundleServicePolicyNotCloseable(policyNftId);
|
292
|
-
}
|
293
|
-
|
294
|
-
instance.getBundleManager().unlinkPolicy(policyNftId);
|
293
|
+
function _getDomain() internal pure override returns(ObjectType) {
|
294
|
+
return BUNDLE();
|
295
295
|
}
|
296
296
|
}
|
@@ -84,10 +84,6 @@ contract PoolService is
|
|
84
84
|
registerInterface(type(IPoolService).interfaceId);
|
85
85
|
}
|
86
86
|
|
87
|
-
function getDomain() public pure override returns(ObjectType) {
|
88
|
-
return POOL();
|
89
|
-
}
|
90
|
-
|
91
87
|
|
92
88
|
function setMaxCapitalAmount(Amount maxCapitalAmount)
|
93
89
|
external
|
@@ -230,7 +226,7 @@ contract PoolService is
|
|
230
226
|
)
|
231
227
|
external
|
232
228
|
virtual
|
233
|
-
restricted
|
229
|
+
restricted()
|
234
230
|
{
|
235
231
|
IRegistry registry = getRegistry();
|
236
232
|
IRegistry.ObjectInfo memory bundleObjectInfo = registry.getObjectInfo(bundleNftId);
|
@@ -311,7 +307,7 @@ contract PoolService is
|
|
311
307
|
)
|
312
308
|
external
|
313
309
|
virtual
|
314
|
-
restricted
|
310
|
+
restricted()
|
315
311
|
{
|
316
312
|
_bundleService.releaseCollateral(
|
317
313
|
instance,
|
@@ -337,7 +333,7 @@ contract PoolService is
|
|
337
333
|
)
|
338
334
|
external
|
339
335
|
virtual
|
340
|
-
restricted
|
336
|
+
restricted()
|
341
337
|
{
|
342
338
|
Amount remainingCollateralAmount = policyInfo.sumInsuredAmount - policyInfo.claimAmount;
|
343
339
|
|
@@ -450,4 +446,7 @@ contract PoolService is
|
|
450
446
|
}
|
451
447
|
}
|
452
448
|
|
449
|
+
function _getDomain() internal pure override returns(ObjectType) {
|
450
|
+
return POOL();
|
451
|
+
}
|
453
452
|
}
|
@@ -80,11 +80,6 @@ contract ApplicationService is
|
|
80
80
|
}
|
81
81
|
|
82
82
|
|
83
|
-
function getDomain() public pure override returns(ObjectType) {
|
84
|
-
return APPLICATION();
|
85
|
-
}
|
86
|
-
|
87
|
-
|
88
83
|
function _checkLinkedpplicationParameters(
|
89
84
|
InstanceReader instanceReader,
|
90
85
|
NftId productNftId,
|
@@ -251,4 +246,9 @@ contract ApplicationService is
|
|
251
246
|
}
|
252
247
|
|
253
248
|
// internal functions
|
249
|
+
|
250
|
+
|
251
|
+
function _getDomain() internal pure override returns(ObjectType) {
|
252
|
+
return APPLICATION();
|
253
|
+
}
|
254
254
|
}
|
@@ -73,11 +73,6 @@ contract ClaimService is
|
|
73
73
|
registerInterface(type(IClaimService).interfaceId);
|
74
74
|
}
|
75
75
|
|
76
|
-
|
77
|
-
function getDomain() public pure override returns(ObjectType) {
|
78
|
-
return CLAIM();
|
79
|
-
}
|
80
|
-
|
81
76
|
function submit(
|
82
77
|
NftId policyNftId,
|
83
78
|
Amount claimAmount,
|
@@ -439,4 +434,9 @@ contract ClaimService is
|
|
439
434
|
// get claim info
|
440
435
|
claimInfo = instanceReader.getClaimInfo(policyNftId, claimId);
|
441
436
|
}
|
437
|
+
|
438
|
+
|
439
|
+
function _getDomain() internal pure override returns(ObjectType) {
|
440
|
+
return CLAIM();
|
441
|
+
}
|
442
442
|
}
|
@@ -45,6 +45,10 @@ interface IClaimService is
|
|
45
45
|
bytes memory claimData
|
46
46
|
) external returns (ClaimId claimId);
|
47
47
|
|
48
|
+
|
49
|
+
// TODO add claim revoke functionality
|
50
|
+
|
51
|
+
|
48
52
|
/// @dev declines the specified claim
|
49
53
|
/// function can only be called by product, policy needs to match with calling product
|
50
54
|
function decline(
|
@@ -53,6 +57,7 @@ interface IClaimService is
|
|
53
57
|
bytes memory data // claim processing data
|
54
58
|
) external;
|
55
59
|
|
60
|
+
|
56
61
|
/// @dev confirms the specified claim and specifies the payout amount
|
57
62
|
/// function can only be called by product, policy needs to match with calling product
|
58
63
|
function confirm(
|
@@ -62,6 +67,7 @@ interface IClaimService is
|
|
62
67
|
bytes memory data // claim processing data
|
63
68
|
) external;
|
64
69
|
|
70
|
+
|
65
71
|
/// @dev closes the specified claim
|
66
72
|
/// function can only be called by product, policy needs to match with calling product
|
67
73
|
function close(
|
@@ -85,11 +85,6 @@ contract PolicyService is
|
|
85
85
|
}
|
86
86
|
|
87
87
|
|
88
|
-
function getDomain() public pure override returns(ObjectType) {
|
89
|
-
return POLICY();
|
90
|
-
}
|
91
|
-
|
92
|
-
|
93
88
|
function _getAndVerifyInstanceAndProduct() internal view returns (Product product) {
|
94
89
|
IRegistry.ObjectInfo memory productInfo;
|
95
90
|
(, productInfo,) = _getAndVerifyActiveComponent(PRODUCT());
|
@@ -472,4 +467,9 @@ contract PolicyService is
|
|
472
467
|
poolWallet = instanceReader.getComponentInfo(productInfo.poolNftId).wallet;
|
473
468
|
productWallet = instanceReader.getComponentInfo(productNftId).wallet;
|
474
469
|
}
|
470
|
+
|
471
|
+
|
472
|
+
function _getDomain() internal pure override returns(ObjectType) {
|
473
|
+
return POLICY();
|
474
|
+
}
|
475
475
|
}
|
@@ -56,11 +56,6 @@ contract PricingService is
|
|
56
56
|
_distributionService = IDistributionService(_getServiceAddress(DISTRIBUTION()));
|
57
57
|
}
|
58
58
|
|
59
|
-
|
60
|
-
function getDomain() public pure override returns(ObjectType) {
|
61
|
-
return PRICE();
|
62
|
-
}
|
63
|
-
|
64
59
|
/// @dev calculates the premium amount for the specified attributes
|
65
60
|
/// also returns the various fee components involved with creating a policy
|
66
61
|
function calculatePremium(
|
@@ -87,7 +82,7 @@ contract PricingService is
|
|
87
82
|
(
|
88
83
|
IRegistry.ObjectInfo memory registryInfo,
|
89
84
|
IInstance instance
|
90
|
-
) = _getAndVerifyComponentInfo(productNftId, PRODUCT());
|
85
|
+
) = _getAndVerifyComponentInfo(productNftId, PRODUCT(), false);
|
91
86
|
|
92
87
|
reader = instance.getInstanceReader();
|
93
88
|
|
@@ -298,4 +293,8 @@ contract PricingService is
|
|
298
293
|
premiumWithTargetWalletAmounts = premium;
|
299
294
|
}
|
300
295
|
|
296
|
+
|
297
|
+
function _getDomain() internal pure override returns(ObjectType) {
|
298
|
+
return PRICE();
|
299
|
+
}
|
301
300
|
}
|
@@ -75,11 +75,6 @@ contract ProductService is
|
|
75
75
|
}
|
76
76
|
|
77
77
|
|
78
|
-
function getDomain() public pure override returns(ObjectType) {
|
79
|
-
return PRODUCT();
|
80
|
-
}
|
81
|
-
|
82
|
-
|
83
78
|
function createRisk(
|
84
79
|
RiskId riskId,
|
85
80
|
bytes memory data
|
@@ -121,4 +116,9 @@ contract ProductService is
|
|
121
116
|
(,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
|
122
117
|
instance.getInstanceStore().updateRiskState(riskId, state);
|
123
118
|
}
|
119
|
+
|
120
|
+
|
121
|
+
function _getDomain() internal pure override returns(ObjectType) {
|
122
|
+
return PRODUCT();
|
123
|
+
}
|
124
124
|
}
|
@@ -60,6 +60,12 @@ contract Registry is
|
|
60
60
|
address public _stakingAddress;
|
61
61
|
ReleaseManager public _releaseManager;
|
62
62
|
|
63
|
+
// TODO
|
64
|
+
// 1). Registry and ReleaseManager must be treated as whole single entity.
|
65
|
+
// But current limitations of EVM does not allow it -> require it to be splitted
|
66
|
+
// 2). Keep onlyReleaseManager modifier
|
67
|
+
// 3). Delete onlyRegistryService in favor of restricted, introduce aditional "domain role", REGISTRY_SERVICE_ROLE
|
68
|
+
// 4). (For GlobalRegistry ONLY) make registerChainRegistry() restricted to GIF_ADMIN_ROLE
|
63
69
|
modifier onlyRegistryService() {
|
64
70
|
if(!_releaseManager.isActiveRegistryService(msg.sender)) {
|
65
71
|
revert ErrorRegistryCallerNotRegistryService();
|
@@ -525,7 +531,7 @@ contract Registry is
|
|
525
531
|
// 1) EACH object type MUST have only one parent type across ALL mappings
|
526
532
|
// 2) DO NOT use object type (e.g. POLCY, BUNDLE, STAKE) as parent type
|
527
533
|
// 3) DO NOT use REGISTRY as object type
|
528
|
-
// 2) DO NOT use PROTOCOL and "
|
534
|
+
// 2) DO NOT use PROTOCOL and "ObjectTypeLib.zero"
|
529
535
|
function _setupValidCoreTypesAndCombinations()
|
530
536
|
private
|
531
537
|
{
|