taler-typescript-core

Wallet core logic and WebUIs for various components
Log | Files | Refs | Submodules | README | LICENSE

commit 0d37ec5e91f6704261070e01bb77d7c46f85b7a2
parent ce326361b4ab87167656b6250fb53a99da70f5e5
Author: Florian Dold <florian@dold.me>
Date:   Tue,  3 Nov 2020 16:46:43 +0100

complain about merchant base URL mismatch, fixing #6616

Diffstat:
Mpackages/taler-wallet-core/src/operations/errors.ts | 8++++++++
Mpackages/taler-wallet-core/src/operations/pay.ts | 20+++++++++++++++++++-
2 files changed, 27 insertions(+), 1 deletion(-)

diff --git a/packages/taler-wallet-core/src/operations/errors.ts b/packages/taler-wallet-core/src/operations/errors.ts @@ -31,6 +31,14 @@ import { TalerErrorCode } from "../TalerErrorCode"; * but the error has already been reported by writing it to the database. */ export class OperationFailedAndReportedError extends Error { + static fromCode( + ec: TalerErrorCode, + message: string, + details: Record<string, unknown>, + ): OperationFailedAndReportedError { + return new OperationFailedAndReportedError(makeErrorDetails(ec, message, details)); + } + constructor(public operationError: TalerErrorDetails) { super(operationError.message); diff --git a/packages/taler-wallet-core/src/operations/pay.ts b/packages/taler-wallet-core/src/operations/pay.ts @@ -56,7 +56,11 @@ import * as Amounts from "../util/amounts"; import { AmountJson } from "../util/amounts"; import { Logger } from "../util/logging"; import { parsePayUri } from "../util/taleruri"; -import { guardOperationException, OperationFailedError } from "./errors"; +import { + guardOperationException, + OperationFailedAndReportedError, + OperationFailedError, +} from "./errors"; import { createRefreshGroup, getTotalRefreshCost } from "./refresh"; import { InternalWalletState, EXCHANGE_COINS_LOCK } from "./state"; import { @@ -661,6 +665,20 @@ async function processDownloadProposalImpl( ); const fulfillmentUrl = parsedContractTerms.fulfillment_url; + const baseUrlForDownload = proposal.merchantBaseUrl; + const baseUrlFromContractTerms = parsedContractTerms.merchant_base_url; + + if (baseUrlForDownload !== baseUrlFromContractTerms) { + throw OperationFailedAndReportedError.fromCode( + TalerErrorCode.WALLET_CONTRACT_TERMS_BASE_URL_MISMATCH, + "merchant base URL mismatch", + { + baseUrlForDownload, + baseUrlFromContractTerms, + }, + ); + } + await ws.db.runWithWriteTransaction( [Stores.proposals, Stores.purchases], async (tx) => {