@etherisc/gif-next 3.0.0-d7939fe-905 → 3.0.0-db9ffbc-172
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 +12 -3
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +2 -2
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +2 -2
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +44 -56
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +145 -100
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +2 -2
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +2 -2
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +2 -2
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +2 -2
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +2 -2
- 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 +2 -2
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +2 -2
- 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/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +12 -12
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +2 -2
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +34 -34
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +20 -20
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightLib.sol/FlightLib.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightLib.sol/FlightLib.json +799 -0
- package/artifacts/contracts/examples/flight/FlightMessageVerifier.sol/FlightMessageVerifier.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightMessageVerifier.sol/FlightMessageVerifier.json +229 -0
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.json +1332 -0
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.json +896 -0
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.json +1466 -0
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.json +844 -0
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.json +2289 -0
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.json +891 -0
- package/artifacts/contracts/examples/flight/FlightProductManager.sol/FlightProductManager.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightProductManager.sol/FlightProductManager.json +711 -0
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.json +586 -0
- package/artifacts/contracts/examples/flight/originalV1.sol/FlightDelayChainlink.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/originalV1.sol/FlightDelayChainlink.json +901 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +17 -17
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +2 -2
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +14 -14
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +18 -18
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +2 -2
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +20 -20
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +20 -20
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +2 -2
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +5 -5
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +102 -114
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +2 -2
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +236 -75
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +2 -2
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +2 -2
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +2 -2
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.dbg.json +1 -1
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.json +2 -2
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +1 -1
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +2 -2
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +2 -2
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +2 -2
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +2 -2
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +2 -2
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +2 -2
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +2 -2
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +2 -2
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +2 -2
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +2 -2
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +2 -2
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +2 -2
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- 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/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +2 -2
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +2 -2
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +2 -2
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +2 -2
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +2 -2
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +20 -20
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +2 -2
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +2 -2
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +2 -2
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +20 -12
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +2 -2
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +2 -2
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +2 -2
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +2 -2
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +2 -2
- 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/IRelease.sol/IRelease.dbg.json +1 -1
- 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 +2 -2
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +101 -113
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +2 -2
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +2 -2
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +2 -2
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +110 -122
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +2 -2
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +56 -62
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +2 -2
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +2 -2
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +2 -2
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +2 -2
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +2 -2
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/IAuthorizedComponent.sol/IAuthorizedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/IAuthorizedComponent.sol/IAuthorizedComponent.json +633 -0
- 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/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.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/InitializableERC165.sol/InitializableERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +2 -2
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +2 -2
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +2 -2
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/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/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +2 -2
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +2 -2
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +2 -2
- 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/ITargetLimitHandler.sol/ITargetLimitHandler.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +2 -2
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +2 -2
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +2 -2
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +2 -2
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +2 -2
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +2 -2
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2 -2
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.json +2 -2
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +2 -2
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ChainId.sol/ChainIdLib.json +2 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +2 -2
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +1 -1
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.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 +22 -25
- 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 +23 -4
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +2 -2
- package/artifacts/contracts/type/RequestIdSet.sol/LibRequestIdSet.dbg.json +4 -0
- package/artifacts/contracts/type/RequestIdSet.sol/LibRequestIdSet.json +33 -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 +2 -2
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +21 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.json +21 -2
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +36 -4
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +2 -2
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
- package/contracts/authorization/AccessAdmin.sol +6 -25
- package/contracts/authorization/AccessAdminLib.sol +20 -3
- package/contracts/examples/flight/FlightLib.sol +337 -0
- package/contracts/examples/flight/FlightMessageVerifier.sol +128 -0
- package/contracts/examples/flight/FlightOracle.sol +206 -0
- package/contracts/examples/flight/FlightOracleAuthorization.sol +53 -0
- package/contracts/examples/flight/FlightPool.sol +89 -0
- package/contracts/examples/flight/FlightPoolAuthorization.sol +37 -0
- package/contracts/examples/flight/FlightProduct.sol +687 -0
- package/contracts/examples/flight/FlightProductAuthorization.sol +70 -0
- package/contracts/examples/flight/FlightProductManager.sol +49 -0
- package/contracts/examples/flight/FlightUSD.sol +28 -0
- package/contracts/examples/flight/originalV1.sol +396 -0
- package/contracts/instance/IInstance.sol +1 -1
- package/contracts/instance/Instance.sol +1 -1
- package/contracts/instance/InstanceAdmin.sol +0 -1
- package/contracts/instance/InstanceReader.sol +41 -7
- package/contracts/oracle/BasicOracle.sol +1 -0
- package/contracts/oracle/IOracleService.sol +12 -12
- package/contracts/oracle/Oracle.sol +2 -2
- package/contracts/product/BasicProductAuthorization.sol +3 -2
- package/contracts/product/PolicyServiceLib.sol +5 -3
- package/contracts/registry/RegistryAdmin.sol +7 -1
- package/contracts/registry/ReleaseAdmin.sol +8 -1
- package/contracts/shared/EcdsaChecker.sol +5 -0
- package/contracts/shared/IAuthorizedComponent.sol +15 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +2 -5
- package/contracts/shared/InstanceLinkedComponent.sol +60 -19
- package/contracts/type/ObjectType.sol +2 -31
- package/contracts/type/Referral.sol +6 -0
- package/contracts/type/RequestIdSet.sol +62 -0
- package/contracts/type/Seconds.sol +4 -0
- package/contracts/type/String.sol +30 -0
- package/contracts/type/Timestamp.sol +10 -1
- package/package.json +2 -1
@@ -0,0 +1,337 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IPolicy} from "../../instance/module/IPolicy.sol";
|
5
|
+
import {IPolicyService} from "../../product/IPolicyService.sol";
|
6
|
+
|
7
|
+
import {Amount, AmountLib} from "../../type/Amount.sol";
|
8
|
+
import {FlightMessageVerifier} from "./FlightMessageVerifier.sol";
|
9
|
+
import {FlightProduct} from "./FlightProduct.sol";
|
10
|
+
import {InstanceReader} from "../../instance/InstanceReader.sol";
|
11
|
+
import {NftId} from "../../type/NftId.sol";
|
12
|
+
import {RequestId} from "../../type/RequestId.sol";
|
13
|
+
import {RiskId, RiskIdLib} from "../../type/RiskId.sol";
|
14
|
+
import {Seconds} from "../../type/Seconds.sol";
|
15
|
+
import {StateId} from "../../type/StateId.sol";
|
16
|
+
import {Str} from "../../type/String.sol";
|
17
|
+
import {Timestamp, TimestampLib} from "../../type/Timestamp.sol";
|
18
|
+
|
19
|
+
|
20
|
+
library FlightLib {
|
21
|
+
|
22
|
+
event LogFlightProductErrorUnprocessableStatus(RequestId requestId, RiskId riskId, bytes1 status);
|
23
|
+
event LogFlightProductErrorUnexpectedStatus(RequestId requestId, RiskId riskId, bytes1 status, int256 delayMinutes);
|
24
|
+
|
25
|
+
error ErrorFlightProductRiskInvalid(RiskId riskId);
|
26
|
+
error ErrorFlightProductPremiumAmountTooSmall(Amount premiumAmount, Amount minPremium);
|
27
|
+
error ErrorFlightProductPremiumAmountTooLarge(Amount premiumAmount, Amount maxPremium);
|
28
|
+
error ErrorFlightProductArrivalBeforeDepartureTime(Timestamp departureTime, Timestamp arrivalTime);
|
29
|
+
error ErrorFlightProductArrivalAfterMaxFlightDuration(Timestamp arrivalTime, Timestamp maxArrivalTime, Seconds maxDuration);
|
30
|
+
error ErrorFlightProductDepartureBeforeMinTimeBeforeDeparture(Timestamp departureTime, Timestamp now, Seconds minTimeBeforeDeparture);
|
31
|
+
error ErrorFlightProductDepartureAfterMaxTimeBeforeDeparture(Timestamp departureTime, Timestamp now, Seconds maxTimeBeforeDeparture);
|
32
|
+
error ErrorFlightProductNotEnoughObservations(uint256 observations, uint256 minObservations);
|
33
|
+
error ErrorFlightProductClusterRisk(Amount totalSumInsured, Amount maxTotalPayout);
|
34
|
+
|
35
|
+
function checkApplicationData(
|
36
|
+
FlightProduct flightProduct,
|
37
|
+
Str flightData,
|
38
|
+
Timestamp departureTime,
|
39
|
+
Timestamp arrivalTime,
|
40
|
+
Amount premiumAmount
|
41
|
+
)
|
42
|
+
public
|
43
|
+
view
|
44
|
+
{
|
45
|
+
_checkApplicationData(flightProduct, premiumAmount, arrivalTime, departureTime);
|
46
|
+
}
|
47
|
+
|
48
|
+
|
49
|
+
function _checkApplicationData(
|
50
|
+
FlightProduct flightProduct,
|
51
|
+
Amount premiumAmount,
|
52
|
+
Timestamp arrivalTime,
|
53
|
+
Timestamp departureTime
|
54
|
+
)
|
55
|
+
internal
|
56
|
+
view
|
57
|
+
{
|
58
|
+
bool testMode = flightProduct.isTestMode();
|
59
|
+
|
60
|
+
// solhint-disable
|
61
|
+
if (premiumAmount < flightProduct.MIN_PREMIUM()) {
|
62
|
+
revert ErrorFlightProductPremiumAmountTooSmall(premiumAmount, flightProduct.MIN_PREMIUM());
|
63
|
+
}
|
64
|
+
if (premiumAmount > flightProduct.MAX_PREMIUM()) {
|
65
|
+
revert ErrorFlightProductPremiumAmountTooLarge(premiumAmount, flightProduct.MAX_PREMIUM());
|
66
|
+
}
|
67
|
+
if (arrivalTime <= departureTime) {
|
68
|
+
revert ErrorFlightProductArrivalBeforeDepartureTime(departureTime, arrivalTime);
|
69
|
+
}
|
70
|
+
if (arrivalTime > departureTime.addSeconds(flightProduct.MAX_FLIGHT_DURATION())) {
|
71
|
+
revert ErrorFlightProductArrivalAfterMaxFlightDuration(arrivalTime, departureTime, flightProduct.MAX_FLIGHT_DURATION());
|
72
|
+
}
|
73
|
+
|
74
|
+
// test mode allows the creation for policies that are outside restricted policy creation times
|
75
|
+
if (!testMode && departureTime < TimestampLib.current().addSeconds(flightProduct.MIN_TIME_BEFORE_DEPARTURE())) {
|
76
|
+
revert ErrorFlightProductDepartureBeforeMinTimeBeforeDeparture(departureTime, TimestampLib.current(), flightProduct.MIN_TIME_BEFORE_DEPARTURE());
|
77
|
+
}
|
78
|
+
if (!testMode && departureTime > TimestampLib.current().addSeconds(flightProduct.MAX_TIME_BEFORE_DEPARTURE())) {
|
79
|
+
revert ErrorFlightProductDepartureAfterMaxTimeBeforeDeparture(departureTime, TimestampLib.current(), flightProduct.MAX_TIME_BEFORE_DEPARTURE());
|
80
|
+
}
|
81
|
+
// solhint-enable
|
82
|
+
}
|
83
|
+
|
84
|
+
|
85
|
+
function checkClusterRisk(
|
86
|
+
Amount sumOfSumInsuredAmounts,
|
87
|
+
Amount sumInsuredAmount,
|
88
|
+
Amount maxTotalPayout
|
89
|
+
)
|
90
|
+
public
|
91
|
+
pure
|
92
|
+
{
|
93
|
+
if (sumOfSumInsuredAmounts + sumInsuredAmount > maxTotalPayout) {
|
94
|
+
revert ErrorFlightProductClusterRisk(sumOfSumInsuredAmounts + sumInsuredAmount, maxTotalPayout);
|
95
|
+
}
|
96
|
+
}
|
97
|
+
|
98
|
+
|
99
|
+
/// @dev calculates payout option based on flight status and delay minutes.
|
100
|
+
/// Is not a view function as it emits log evens in case of unexpected status.
|
101
|
+
function checkAndGetPayoutOption(
|
102
|
+
RequestId requestId,
|
103
|
+
RiskId riskId,
|
104
|
+
bytes1 status,
|
105
|
+
int256 delayMinutes
|
106
|
+
)
|
107
|
+
public
|
108
|
+
returns (uint8 payoutOption)
|
109
|
+
{
|
110
|
+
// default: no payout
|
111
|
+
payoutOption = type(uint8).max;
|
112
|
+
|
113
|
+
// check status
|
114
|
+
if (status != "L" && status != "A" && status != "C" && status != "D") {
|
115
|
+
emit LogFlightProductErrorUnprocessableStatus(requestId, riskId, status);
|
116
|
+
return payoutOption;
|
117
|
+
}
|
118
|
+
|
119
|
+
if (status == "A") {
|
120
|
+
// todo: active, reschedule oracle call + 45 min
|
121
|
+
emit LogFlightProductErrorUnexpectedStatus(requestId, riskId, status, delayMinutes);
|
122
|
+
return payoutOption;
|
123
|
+
}
|
124
|
+
|
125
|
+
// trigger payout if applicable
|
126
|
+
if (status == "C") { payoutOption = 3; }
|
127
|
+
else if (status == "D") { payoutOption = 4; }
|
128
|
+
else if (delayMinutes >= 15 && delayMinutes < 30) { payoutOption = 0; }
|
129
|
+
else if (delayMinutes >= 30 && delayMinutes < 45) { payoutOption = 1; }
|
130
|
+
else if (delayMinutes >= 45) { payoutOption = 2; }
|
131
|
+
}
|
132
|
+
|
133
|
+
|
134
|
+
function calculateWeight(
|
135
|
+
FlightProduct flightProduct,
|
136
|
+
uint256[6] memory statistics
|
137
|
+
)
|
138
|
+
public
|
139
|
+
view
|
140
|
+
returns (uint256 weight)
|
141
|
+
{
|
142
|
+
// check we have enough observations
|
143
|
+
if (statistics[0] < flightProduct.MIN_OBSERVATIONS()) {
|
144
|
+
revert ErrorFlightProductNotEnoughObservations(statistics[0], flightProduct.MIN_OBSERVATIONS());
|
145
|
+
}
|
146
|
+
|
147
|
+
weight = 0;
|
148
|
+
for (uint256 i = 1; i < 6; i++) {
|
149
|
+
weight += flightProduct.WEIGHT_PATTERN(i) * statistics[i] * 10000 / statistics[0];
|
150
|
+
}
|
151
|
+
|
152
|
+
// To avoid div0 in the payout section, we have to make a minimal assumption on weight
|
153
|
+
if (weight == 0) {
|
154
|
+
weight = 100000 / statistics[0];
|
155
|
+
}
|
156
|
+
|
157
|
+
// TODO comment on intended effect
|
158
|
+
weight = (weight * (100 + flightProduct.MARGIN_PERCENT())) / 100;
|
159
|
+
}
|
160
|
+
|
161
|
+
|
162
|
+
// REMARK: each flight may get different payouts depending on the latest statics
|
163
|
+
function calculatePayoutAmounts(
|
164
|
+
FlightProduct flightProduct,
|
165
|
+
Amount premium,
|
166
|
+
uint256[6] memory statistics
|
167
|
+
)
|
168
|
+
public
|
169
|
+
view
|
170
|
+
returns (
|
171
|
+
uint256 weight,
|
172
|
+
Amount[5] memory payoutAmounts,
|
173
|
+
Amount sumInsuredAmount // simply the max of payoutAmounts
|
174
|
+
)
|
175
|
+
{
|
176
|
+
if (premium < flightProduct.MIN_PREMIUM()) {
|
177
|
+
revert ErrorFlightProductPremiumAmountTooSmall(premium, flightProduct.MIN_PREMIUM());
|
178
|
+
}
|
179
|
+
if (premium > flightProduct.MAX_PREMIUM()) {
|
180
|
+
revert ErrorFlightProductPremiumAmountTooLarge(premium, flightProduct.MAX_PREMIUM());
|
181
|
+
}
|
182
|
+
|
183
|
+
sumInsuredAmount = AmountLib.zero();
|
184
|
+
weight = calculateWeight(flightProduct, statistics);
|
185
|
+
|
186
|
+
for (uint256 i = 0; i < 5; i++) {
|
187
|
+
Amount payoutAmount = AmountLib.toAmount(
|
188
|
+
premium.toInt() * flightProduct.WEIGHT_PATTERN(i + 1) * 10000 / weight);
|
189
|
+
|
190
|
+
// cap payout and update sum insured if applicable
|
191
|
+
if (payoutAmount > flightProduct.MAX_PAYOUT()) { payoutAmount = flightProduct.MAX_PAYOUT(); }
|
192
|
+
if (payoutAmount > sumInsuredAmount) { sumInsuredAmount = payoutAmount; }
|
193
|
+
|
194
|
+
payoutAmounts[i] = payoutAmount;
|
195
|
+
}
|
196
|
+
}
|
197
|
+
|
198
|
+
|
199
|
+
function getPayoutOption(
|
200
|
+
InstanceReader reader,
|
201
|
+
NftId productNftId,
|
202
|
+
RiskId riskId
|
203
|
+
)
|
204
|
+
public
|
205
|
+
view
|
206
|
+
returns (
|
207
|
+
bool exists,
|
208
|
+
bool statusAvailable,
|
209
|
+
uint8 payoutOption
|
210
|
+
)
|
211
|
+
{
|
212
|
+
FlightProduct.FlightRisk memory flightRisk;
|
213
|
+
(exists, flightRisk) = getFlightRisk(
|
214
|
+
reader,
|
215
|
+
productNftId,
|
216
|
+
riskId,
|
217
|
+
false);
|
218
|
+
|
219
|
+
statusAvailable = flightRisk.statusUpdatedAt.gtz();
|
220
|
+
payoutOption = flightRisk.payoutOption;
|
221
|
+
}
|
222
|
+
|
223
|
+
|
224
|
+
function getPayoutAmount(
|
225
|
+
bytes memory applicationData,
|
226
|
+
uint8 payoutOption
|
227
|
+
)
|
228
|
+
public
|
229
|
+
pure
|
230
|
+
returns (Amount payoutAmount)
|
231
|
+
{
|
232
|
+
if (payoutOption == type(uint8).max) {
|
233
|
+
return AmountLib.zero();
|
234
|
+
}
|
235
|
+
|
236
|
+
// retrieve payout amounts from application data
|
237
|
+
(, Amount[5] memory payoutAmounts) = abi.decode(
|
238
|
+
applicationData, (Amount, Amount[5]));
|
239
|
+
|
240
|
+
// get payout amount for selected option
|
241
|
+
payoutAmount = payoutAmounts[payoutOption];
|
242
|
+
}
|
243
|
+
|
244
|
+
|
245
|
+
function getFlightRisk(
|
246
|
+
InstanceReader reader,
|
247
|
+
NftId productNftId,
|
248
|
+
Str flightData,
|
249
|
+
Timestamp departureTime,
|
250
|
+
string memory departureTimeLocal,
|
251
|
+
Timestamp arrivalTime,
|
252
|
+
string memory arrivalTimeLocal
|
253
|
+
)
|
254
|
+
public
|
255
|
+
view
|
256
|
+
returns (
|
257
|
+
RiskId riskId,
|
258
|
+
bool exists,
|
259
|
+
FlightProduct.FlightRisk memory flightRisk
|
260
|
+
)
|
261
|
+
{
|
262
|
+
riskId = getRiskId(productNftId, flightData);
|
263
|
+
(exists, flightRisk) = getFlightRisk(reader, productNftId, riskId, false);
|
264
|
+
|
265
|
+
// create new risk if not existing
|
266
|
+
if (!exists) {
|
267
|
+
flightRisk = FlightProduct.FlightRisk({
|
268
|
+
flightData: flightData,
|
269
|
+
departureTime: departureTime,
|
270
|
+
departureTimeLocal: departureTimeLocal,
|
271
|
+
arrivalTime: arrivalTime,
|
272
|
+
arrivalTimeLocal: arrivalTimeLocal,
|
273
|
+
sumOfSumInsuredAmounts: AmountLib.toAmount(0),
|
274
|
+
status: bytes1(0),
|
275
|
+
delayMinutes: 0,
|
276
|
+
payoutOption: uint8(0),
|
277
|
+
statusUpdatedAt: TimestampLib.zero()});
|
278
|
+
}
|
279
|
+
}
|
280
|
+
|
281
|
+
|
282
|
+
function getFlightRisk(
|
283
|
+
InstanceReader reader,
|
284
|
+
NftId productNftId,
|
285
|
+
RiskId riskId,
|
286
|
+
bool requireRiskExists
|
287
|
+
)
|
288
|
+
public
|
289
|
+
view
|
290
|
+
returns (
|
291
|
+
bool exists,
|
292
|
+
FlightProduct.FlightRisk memory flightRisk
|
293
|
+
)
|
294
|
+
{
|
295
|
+
// check if risk exists
|
296
|
+
exists = reader.isProductRisk(productNftId, riskId);
|
297
|
+
|
298
|
+
if (!exists && requireRiskExists) {
|
299
|
+
revert ErrorFlightProductRiskInvalid(riskId);
|
300
|
+
}
|
301
|
+
|
302
|
+
// get risk data if risk exists
|
303
|
+
if (exists) {
|
304
|
+
flightRisk = abi.decode(
|
305
|
+
reader.getRiskInfo(riskId).data, (FlightProduct.FlightRisk));
|
306
|
+
}
|
307
|
+
}
|
308
|
+
|
309
|
+
|
310
|
+
function getRiskId(
|
311
|
+
NftId productNftId,
|
312
|
+
Str flightData
|
313
|
+
)
|
314
|
+
public
|
315
|
+
view
|
316
|
+
returns (RiskId riskId)
|
317
|
+
{
|
318
|
+
bytes32 riskKey = getRiskKey(flightData);
|
319
|
+
riskId = getRiskId(productNftId, riskKey);
|
320
|
+
}
|
321
|
+
|
322
|
+
|
323
|
+
function getRiskKey(
|
324
|
+
Str flightData
|
325
|
+
)
|
326
|
+
internal
|
327
|
+
pure
|
328
|
+
returns (bytes32 riskKey)
|
329
|
+
{
|
330
|
+
return keccak256(abi.encode(flightData));
|
331
|
+
}
|
332
|
+
|
333
|
+
|
334
|
+
function getRiskId(NftId productNftId, bytes32 riskKey) internal view returns (RiskId riskId) {
|
335
|
+
return RiskIdLib.toRiskId(productNftId, riskKey);
|
336
|
+
}
|
337
|
+
}
|
@@ -0,0 +1,128 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Ownable} from "@openzeppelin/contracts/access/Ownable.sol";
|
5
|
+
import {MessageHashUtils} from "@openzeppelin/contracts/utils/cryptography/MessageHashUtils.sol";
|
6
|
+
import {ECDSA} from "@openzeppelin/contracts/utils/cryptography/ECDSA.sol";
|
7
|
+
|
8
|
+
|
9
|
+
import {Amount} from "../../type/Amount.sol";
|
10
|
+
import {Str} from "../../type/String.sol";
|
11
|
+
import {Timestamp} from "../../type/Timestamp.sol";
|
12
|
+
|
13
|
+
contract FlightMessageVerifier is
|
14
|
+
Ownable
|
15
|
+
{
|
16
|
+
|
17
|
+
error ErrorFlightMessageVerifierSignerZero();
|
18
|
+
error ErrorFlightMessageVerifierContractSignerNotSupported();
|
19
|
+
|
20
|
+
address private _expectedSigner;
|
21
|
+
|
22
|
+
|
23
|
+
constructor() Ownable(msg.sender) { }
|
24
|
+
|
25
|
+
|
26
|
+
function setExpectedSigner(address signer) external onlyOwner {
|
27
|
+
if (signer == address(0)) { revert ErrorFlightMessageVerifierSignerZero(); }
|
28
|
+
if (signer.code.length > 0) { revert ErrorFlightMessageVerifierContractSignerNotSupported(); }
|
29
|
+
_expectedSigner = signer;
|
30
|
+
}
|
31
|
+
|
32
|
+
|
33
|
+
function getExpectedSigner() external view returns(address) {
|
34
|
+
return _expectedSigner;
|
35
|
+
}
|
36
|
+
|
37
|
+
/// @dev creates digest hash based on application parameters
|
38
|
+
/// proposal:
|
39
|
+
/// use "LX 180 ZRH BKK 20241104" (23 chars, should be enough for all flights)
|
40
|
+
/// carriers, airports: https://www.iata.org/en/publications/directories/code-search/
|
41
|
+
/// flight numbers: https://en.wikipedia.org/wiki/Flight_number
|
42
|
+
/// instead of separate strings, coding/decoding done anyway off-chain
|
43
|
+
function getRatingsHash(
|
44
|
+
Str flightData,
|
45
|
+
Timestamp departureTime,
|
46
|
+
Timestamp arrivalTime,
|
47
|
+
Amount premiumAmount,
|
48
|
+
uint256[6] memory statistics
|
49
|
+
)
|
50
|
+
public
|
51
|
+
view
|
52
|
+
returns(bytes32)
|
53
|
+
{
|
54
|
+
return MessageHashUtils.toEthSignedMessageHash(
|
55
|
+
abi.encode(
|
56
|
+
flightData,
|
57
|
+
departureTime,
|
58
|
+
arrivalTime,
|
59
|
+
premiumAmount,
|
60
|
+
statistics));
|
61
|
+
}
|
62
|
+
|
63
|
+
|
64
|
+
function verifyRatingsHash(
|
65
|
+
Str flightData,
|
66
|
+
Timestamp departureTime,
|
67
|
+
Timestamp arrivalTime,
|
68
|
+
Amount premiumAmount,
|
69
|
+
uint256[6] memory statistics,
|
70
|
+
// bytes memory signature,
|
71
|
+
uint8 v,
|
72
|
+
bytes32 r,
|
73
|
+
bytes32 s
|
74
|
+
)
|
75
|
+
public
|
76
|
+
view
|
77
|
+
returns (
|
78
|
+
address actualSigner,
|
79
|
+
ECDSA.RecoverError errorStatus,
|
80
|
+
bool success
|
81
|
+
)
|
82
|
+
{
|
83
|
+
bytes32 messageHash = getRatingsHash(
|
84
|
+
flightData,
|
85
|
+
departureTime,
|
86
|
+
arrivalTime,
|
87
|
+
premiumAmount,
|
88
|
+
statistics);
|
89
|
+
|
90
|
+
(
|
91
|
+
actualSigner,
|
92
|
+
errorStatus,
|
93
|
+
) = ECDSA.tryRecover(messageHash, v, r, s);
|
94
|
+
|
95
|
+
success = (
|
96
|
+
errorStatus == ECDSA.RecoverError.NoError
|
97
|
+
&& actualSigner == _expectedSigner);
|
98
|
+
}
|
99
|
+
|
100
|
+
|
101
|
+
// TODO re-enable or cleanup
|
102
|
+
// function checkAndRegisterSignature (
|
103
|
+
// address policyHolder,
|
104
|
+
// address protectedWallet,
|
105
|
+
// uint256 protectedBalance,
|
106
|
+
// uint256 duration,
|
107
|
+
// uint256 bundleId,
|
108
|
+
// bytes32 signatureId,
|
109
|
+
// bytes calldata signature
|
110
|
+
// )
|
111
|
+
// external
|
112
|
+
// {
|
113
|
+
// bytes32 signatureHash = keccak256(abi.encode(signature));
|
114
|
+
// require(!_signatureIsUsed[signatureHash], "ERROR:DMH-001:SIGNATURE_USED");
|
115
|
+
|
116
|
+
// address signer = getSignerFromDigestAndSignature(
|
117
|
+
// protectedWallet,
|
118
|
+
// protectedBalance,
|
119
|
+
// duration,
|
120
|
+
// bundleId,
|
121
|
+
// signatureId,
|
122
|
+
// signature);
|
123
|
+
|
124
|
+
// require(policyHolder == signer, "ERROR:DMH-002:SIGNATURE_INVALID");
|
125
|
+
|
126
|
+
// _signatureIsUsed[signatureHash] = true;
|
127
|
+
// }
|
128
|
+
}
|
@@ -0,0 +1,206 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IAuthorization} from "../../authorization/IAuthorization.sol";
|
5
|
+
|
6
|
+
import {ACTIVE, FULFILLED, FAILED} from "../../type/StateId.sol";
|
7
|
+
import {NftId} from "../../type/NftId.sol";
|
8
|
+
import {BasicOracle} from "../../oracle/BasicOracle.sol";
|
9
|
+
import {RequestId} from "../../type/RequestId.sol";
|
10
|
+
import {LibRequestIdSet} from "../../type/RequestIdSet.sol";
|
11
|
+
import {RiskId} from "../../type/RiskId.sol";
|
12
|
+
import {StateId} from "../../type/StateId.sol";
|
13
|
+
import {Str} from "../../type/String.sol";
|
14
|
+
import {Timestamp, TimestampLib} from "../../type/Timestamp.sol";
|
15
|
+
|
16
|
+
contract FlightOracle is
|
17
|
+
BasicOracle
|
18
|
+
{
|
19
|
+
|
20
|
+
struct FlightStatusRequest {
|
21
|
+
RiskId riskId;
|
22
|
+
Str flightData; // "LX 180 ZRH BKK 20241104"
|
23
|
+
Timestamp departureTime; // is this needed or is flight number and date unique aready?
|
24
|
+
}
|
25
|
+
|
26
|
+
struct FlightStatusResponse {
|
27
|
+
RiskId riskId;
|
28
|
+
bytes1 status;
|
29
|
+
int256 delayMinutes;
|
30
|
+
}
|
31
|
+
|
32
|
+
event LogFlightOracleRequestReceived(RequestId requestId, NftId requesterId);
|
33
|
+
event LogFlightOracleResponseSent(RequestId requestId, bytes1 status, int256 delay);
|
34
|
+
event LogFlightOracleRequestCancelled(RequestId requestId);
|
35
|
+
|
36
|
+
// TODO decide if this variable should be moved to instance store
|
37
|
+
// if so it need to manage active requests by requestor nft id
|
38
|
+
LibRequestIdSet.Set internal _activeRequests;
|
39
|
+
|
40
|
+
|
41
|
+
constructor(
|
42
|
+
address registry,
|
43
|
+
NftId productNftId,
|
44
|
+
string memory componentName,
|
45
|
+
IAuthorization authorization
|
46
|
+
)
|
47
|
+
{
|
48
|
+
address initialOwner = msg.sender;
|
49
|
+
initialize(
|
50
|
+
registry,
|
51
|
+
productNftId,
|
52
|
+
authorization,
|
53
|
+
initialOwner,
|
54
|
+
componentName
|
55
|
+
);
|
56
|
+
}
|
57
|
+
|
58
|
+
|
59
|
+
function initialize(
|
60
|
+
address registry,
|
61
|
+
NftId productNftId,
|
62
|
+
IAuthorization authorization,
|
63
|
+
address initialOwner,
|
64
|
+
string memory name
|
65
|
+
)
|
66
|
+
public
|
67
|
+
virtual
|
68
|
+
initializer()
|
69
|
+
{
|
70
|
+
_initializeBasicOracle(
|
71
|
+
registry,
|
72
|
+
productNftId,
|
73
|
+
authorization,
|
74
|
+
initialOwner,
|
75
|
+
name);
|
76
|
+
}
|
77
|
+
|
78
|
+
|
79
|
+
function respondWithFlightStatus(
|
80
|
+
RequestId requestId,
|
81
|
+
bytes1 status,
|
82
|
+
int256 delayMinutes
|
83
|
+
)
|
84
|
+
external
|
85
|
+
restricted()
|
86
|
+
{
|
87
|
+
// obtain riskId for request
|
88
|
+
bytes memory requestData = _getInstanceReader().getRequestInfo(requestId).requestData;
|
89
|
+
(RiskId riskId,,) = abi.decode(requestData, (RiskId, Str, Timestamp));
|
90
|
+
// assemble response data
|
91
|
+
bytes memory responseData = abi.encode(
|
92
|
+
FlightStatusResponse ({
|
93
|
+
riskId: riskId,
|
94
|
+
status: status,
|
95
|
+
delayMinutes: delayMinutes}));
|
96
|
+
|
97
|
+
// logging
|
98
|
+
emit LogFlightOracleResponseSent(requestId, status, delayMinutes);
|
99
|
+
|
100
|
+
// effects + interaction (via framework to receiving component)
|
101
|
+
_respond(requestId, responseData);
|
102
|
+
|
103
|
+
// TODO decide if the code below should be moved to GIF
|
104
|
+
// check callback result
|
105
|
+
bool requestFulfilled = _getInstanceReader().getRequestState(
|
106
|
+
requestId) == FULFILLED();
|
107
|
+
|
108
|
+
// remove from active requests when successful
|
109
|
+
if (requestFulfilled) {
|
110
|
+
LibRequestIdSet.remove(_activeRequests, requestId);
|
111
|
+
}
|
112
|
+
}
|
113
|
+
|
114
|
+
|
115
|
+
//--- view functions ----------------------------------------------------//
|
116
|
+
|
117
|
+
// TODO decide if the code below should be moved to GIF
|
118
|
+
function activeRequests()
|
119
|
+
external
|
120
|
+
view
|
121
|
+
returns(uint256 numberOfRequests)
|
122
|
+
{
|
123
|
+
return LibRequestIdSet.size(_activeRequests);
|
124
|
+
}
|
125
|
+
|
126
|
+
|
127
|
+
// TODO decide if the code below should be moved to GIF
|
128
|
+
function getActiveRequest(uint256 idx)
|
129
|
+
external
|
130
|
+
view
|
131
|
+
returns(RequestId requestId)
|
132
|
+
{
|
133
|
+
return LibRequestIdSet.getElementAt(_activeRequests, idx);
|
134
|
+
}
|
135
|
+
|
136
|
+
|
137
|
+
function isActiveRequest(RequestId requestId)
|
138
|
+
external
|
139
|
+
view
|
140
|
+
returns(bool isActive)
|
141
|
+
{
|
142
|
+
return LibRequestIdSet.contains(_activeRequests, requestId);
|
143
|
+
}
|
144
|
+
|
145
|
+
|
146
|
+
function getRequestState(RequestId requestId)
|
147
|
+
external
|
148
|
+
view
|
149
|
+
returns (
|
150
|
+
RiskId riskId,
|
151
|
+
string memory flightData,
|
152
|
+
StateId requestState,
|
153
|
+
bool readyForResponse,
|
154
|
+
bool waitingForResend
|
155
|
+
)
|
156
|
+
{
|
157
|
+
bytes memory requestData = _getInstanceReader().getRequestInfo(requestId).requestData;
|
158
|
+
Str fltData;
|
159
|
+
Timestamp departureTime;
|
160
|
+
(riskId, fltData, departureTime) = abi.decode(requestData, (RiskId, Str, Timestamp));
|
161
|
+
|
162
|
+
flightData = fltData.toString();
|
163
|
+
requestState = _getInstanceReader().getRequestState(requestId);
|
164
|
+
readyForResponse = requestState == ACTIVE() && TimestampLib.current() >= departureTime;
|
165
|
+
waitingForResend = requestState == FAILED();
|
166
|
+
}
|
167
|
+
|
168
|
+
|
169
|
+
function decodeFlightStatusRequestData(bytes memory data) external pure returns (FlightStatusRequest memory) {
|
170
|
+
return abi.decode(data, (FlightStatusRequest));
|
171
|
+
}
|
172
|
+
|
173
|
+
//--- internal functions ------------------------------------------------//
|
174
|
+
|
175
|
+
/// @dev use case specific handling of oracle requests
|
176
|
+
/// for now only log is emitted to verify that request has been received by oracle component
|
177
|
+
function _request(
|
178
|
+
RequestId requestId,
|
179
|
+
NftId requesterId,
|
180
|
+
bytes calldata requestData,
|
181
|
+
Timestamp expiryAt
|
182
|
+
)
|
183
|
+
internal
|
184
|
+
virtual override
|
185
|
+
{
|
186
|
+
FlightStatusRequest memory request = abi.decode(requestData, (FlightStatusRequest));
|
187
|
+
|
188
|
+
// TODO decide if the line below should be moved to GIF
|
189
|
+
LibRequestIdSet.add(_activeRequests, requestId);
|
190
|
+
emit LogFlightOracleRequestReceived(requestId, requesterId);
|
191
|
+
}
|
192
|
+
|
193
|
+
|
194
|
+
/// @dev use case specific handling of oracle requests
|
195
|
+
/// for now only log is emitted to verify that cancelling has been received by oracle component
|
196
|
+
function _cancel(
|
197
|
+
RequestId requestId
|
198
|
+
)
|
199
|
+
internal
|
200
|
+
virtual override
|
201
|
+
{
|
202
|
+
// TODO decide if the line below should be moved to GIF
|
203
|
+
LibRequestIdSet.remove(_activeRequests, requestId);
|
204
|
+
emit LogFlightOracleRequestCancelled(requestId);
|
205
|
+
}
|
206
|
+
}
|