@etherisc/gif-next 3.0.0-24be7ed-702 → 3.0.0-26d0489-938
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 +10 -1
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +42 -56
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +15 -19
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +14 -20
- 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 +25 -6
- 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 +157 -72
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +37 -37
- 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 +85 -0
- 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/FlightNft.sol/FlightNft.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightNft.sol/FlightNft.json +801 -0
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.json +1353 -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/BaseStore.sol/BaseStore.json +50 -0
- 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/IBaseStore.sol/IBaseStore.json +50 -0
- 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/IInstanceService.sol/IInstanceService.json +61 -0
- 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 +81 -20
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +11 -11
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +82 -32
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.dbg.json +1 -1
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.json +68 -18
- 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 +32 -20
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +11 -11
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +12 -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 +12 -0
- 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 +36 -24
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +13 -13
- 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/IPolicyService.sol/IPolicyService.json +12 -0
- 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 +56 -44
- 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 +23 -23
- 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/ChainNft.sol/ChainNft.json +2 -2
- 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 +51 -26
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +14 -14
- 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/IComponentService.sol/IComponentService.json +25 -0
- 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/IStaking.sol/IStaking.json +25 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +12 -0
- 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 +73 -48
- 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 +25 -25
- 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 +26 -14
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +8 -8
- 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/accounting/AccountingService.sol +17 -29
- package/contracts/accounting/IAccountingService.sol +7 -8
- package/contracts/authorization/AccessAdmin.sol +6 -25
- package/contracts/authorization/AccessAdminLib.sol +20 -3
- package/contracts/authorization/AccessManagerCloneable.sol +3 -0
- package/contracts/distribution/DistributionService.sol +5 -3
- package/contracts/distribution/IDistributionService.sol +4 -3
- package/contracts/examples/flight/FlightLib.sol +337 -0
- package/contracts/examples/flight/FlightMessageVerifier.sol +128 -0
- package/contracts/examples/flight/FlightNft.sol +234 -0
- package/contracts/examples/flight/FlightOracle.sol +226 -0
- package/contracts/examples/flight/FlightOracleAuthorization.sol +57 -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/BaseStore.sol +4 -0
- package/contracts/instance/IBaseStore.sol +8 -0
- package/contracts/instance/IInstance.sol +1 -1
- package/contracts/instance/IInstanceService.sol +2 -0
- package/contracts/instance/Instance.sol +1 -1
- package/contracts/instance/InstanceAdmin.sol +0 -1
- package/contracts/instance/InstanceReader.sol +41 -7
- package/contracts/instance/InstanceService.sol +4 -0
- package/contracts/oracle/BasicOracle.sol +1 -0
- package/contracts/oracle/IOracleService.sol +12 -12
- package/contracts/oracle/Oracle.sol +2 -2
- package/contracts/pool/BundleService.sol +1 -1
- package/contracts/pool/IBundleService.sol +1 -1
- package/contracts/pool/IPoolService.sol +1 -1
- package/contracts/pool/PoolService.sol +1 -1
- package/contracts/product/BasicProductAuthorization.sol +3 -2
- package/contracts/product/IPolicyService.sol +1 -1
- package/contracts/product/PolicyService.sol +1 -1
- package/contracts/product/PolicyServiceLib.sol +5 -3
- package/contracts/registry/ChainNft.sol +1 -1
- package/contracts/registry/RegistryAdmin.sol +7 -1
- package/contracts/registry/ReleaseAdmin.sol +8 -1
- package/contracts/shared/ComponentService.sol +5 -0
- package/contracts/shared/EcdsaChecker.sol +5 -0
- package/contracts/shared/IAuthorizedComponent.sol +15 -0
- package/contracts/shared/IComponentService.sol +1 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +2 -5
- package/contracts/shared/InstanceLinkedComponent.sol +60 -19
- package/contracts/staking/IStaking.sol +2 -0
- package/contracts/staking/IStakingService.sol +1 -1
- package/contracts/staking/Staking.sol +1 -0
- package/contracts/staking/StakingService.sol +1 -1
- 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
| @@ -24,6 +24,8 @@ contract AccessManagerCloneable is | |
| 24 24 | 
             
                error ErrorAccessManagerTargetAdminLocked(address target);
         | 
| 25 25 | 
             
                error ErrorAccessManagerCallerAdminLocked(address caller);
         | 
| 26 26 |  | 
| 27 | 
            +
                event LogAccessManagerLocked(address indexed accessManager, bool indexed locked);
         | 
| 28 | 
            +
             | 
| 27 29 | 
             
                VersionPart private _release;
         | 
| 28 30 | 
             
                bool private _isLocked;
         | 
| 29 31 |  | 
| @@ -94,6 +96,7 @@ contract AccessManagerCloneable is | |
| 94 96 | 
             
                    onlyAdminRole() 
         | 
| 95 97 | 
             
                {
         | 
| 96 98 | 
             
                    _isLocked = locked;
         | 
| 99 | 
            +
                    emit LogAccessManagerLocked(address(this), locked);
         | 
| 97 100 | 
             
                }
         | 
| 98 101 |  | 
| 99 102 |  | 
| @@ -112,7 +112,7 @@ contract DistributionService is | |
| 112 112 |  | 
| 113 113 | 
             
                    instance.getInstanceStore().createDistributorType(distributorType, info);
         | 
| 114 114 |  | 
| 115 | 
            -
                    emit LogDistributionServiceDistributorTypeCreated(distributionNftId, name);
         | 
| 115 | 
            +
                    emit LogDistributionServiceDistributorTypeCreated(distributionNftId, name, commissionPercentage);
         | 
| 116 116 | 
             
                }
         | 
| 117 117 |  | 
| 118 118 |  | 
| @@ -236,7 +236,7 @@ contract DistributionService is | |
| 236 236 |  | 
| 237 237 | 
             
                        instance.getInstanceStore().createReferral(referralId, info);
         | 
| 238 238 |  | 
| 239 | 
            -
                        emit LogDistributionServiceReferralCreated(distributionNftId, distributorNftId, referralId, code);
         | 
| 239 | 
            +
                        emit LogDistributionServiceReferralCreated(distributionNftId, distributorNftId, referralId, code, discountPercentage, maxReferrals, expiryAt);
         | 
| 240 240 | 
             
                    }
         | 
| 241 241 | 
             
                }
         | 
| 242 242 |  | 
| @@ -295,12 +295,14 @@ contract DistributionService is | |
| 295 295 | 
             
                        IDistribution.DistributorInfo memory distributorInfo = reader.getDistributorInfo(referralInfo.distributorNftId);
         | 
| 296 296 | 
             
                        distributorInfo.numPoliciesSold += 1;
         | 
| 297 297 | 
             
                        store.updateDistributor(referralInfo.distributorNftId, distributorInfo, KEEP_STATE());
         | 
| 298 | 
            +
                        emit LogDistributionServiceSaleProcessedWithReferral(distributionNftId, referralInfo.distributorNftId, referralId, distributorInfo.numPoliciesSold, premium.premiumAmount, distributionOwnerFee, commissionAmount);
         | 
| 298 299 | 
             
                    } else {
         | 
| 299 300 | 
             
                        // increase distribution balance by distribution owner fee
         | 
| 300 301 | 
             
                        _accountingService.increaseDistributionBalance(store, distributionNftId, AmountLib.zero(), distributionOwnerFee);
         | 
| 302 | 
            +
                        emit LogDistributionServiceSaleProcessed(distributionNftId, referralId, premium.premiumAmount, distributionOwnerFee);
         | 
| 301 303 | 
             
                    }
         | 
| 302 304 |  | 
| 303 | 
            -
                     | 
| 305 | 
            +
                    
         | 
| 304 306 | 
             
                }
         | 
| 305 307 |  | 
| 306 308 | 
             
                /// @inheritdoc IDistributionService
         | 
| @@ -40,12 +40,13 @@ interface IDistributionService is IService { | |
| 40 40 | 
             
                error ErrorDistributionServiceReferralDistributionMismatch(ReferralId referralId, NftId referralDistributionNft, NftId distributionNftId);
         | 
| 41 41 |  | 
| 42 42 | 
             
                event LogDistributionServiceCommissionWithdrawn(NftId distributorNftId, address recipient, address tokenAddress, Amount amount);
         | 
| 43 | 
            -
                event LogDistributionServiceDistributorTypeCreated(NftId distributionNftId, string name);
         | 
| 43 | 
            +
                event LogDistributionServiceDistributorTypeCreated(NftId distributionNftId, string name, UFixed commissionPercentage);
         | 
| 44 44 | 
             
                event LogDistributionServiceDistributorCreated(NftId distributionNftId, NftId distributorNftId, DistributorType distributorType, address distributor);
         | 
| 45 45 | 
             
                event LogDistributionServiceDistributorTypeChanged(NftId distributorNftId, DistributorType oldDistributorType, DistributorType newDistributorType);
         | 
| 46 | 
            -
                event LogDistributionServiceReferralCreated(NftId distributionNftId, NftId distributorNftId, ReferralId referralId, string code);
         | 
| 46 | 
            +
                event LogDistributionServiceReferralCreated(NftId distributionNftId, NftId distributorNftId, ReferralId referralId, string code, UFixed discountPercentage, uint32 maxReferrals, Timestamp expiryAt);
         | 
| 47 47 | 
             
                event LogDistributionServiceReferralProcessed(NftId distributionNftId, NftId distributorNftId, ReferralId referralId, uint32 usedReferrals);
         | 
| 48 | 
            -
                event LogDistributionServiceSaleProcessed(NftId distributionNftId, ReferralId referralId);
         | 
| 48 | 
            +
                event LogDistributionServiceSaleProcessed(NftId distributionNftId, ReferralId referralId, Amount premium, Amount distributionOwnerFee);
         | 
| 49 | 
            +
                event LogDistributionServiceSaleProcessedWithReferral(NftId distributionNftId, NftId distributorNftId, ReferralId referralId, uint32 numPoliciesSold, Amount premium, Amount distributionOwnerFee, Amount commissionAmount);
         | 
| 49 50 |  | 
| 50 51 | 
             
                function createDistributorType(
         | 
| 51 52 | 
             
                    string memory name,
         | 
| @@ -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 | 
            +
            }
         |