diff --git a/src/dbTypes.ts b/src/dbTypes.ts index 9e9663219..609c85265 100644 --- a/src/dbTypes.ts +++ b/src/dbTypes.ts @@ -784,6 +784,7 @@ export interface PurchaseRecord { timestamp_refund: number; lastSessionSig: string | undefined; + lastSessionId: string | undefined; } diff --git a/src/i18n/de.po b/src/i18n/de.po index 1f6e98962..39f1f56e6 100644 --- a/src/i18n/de.po +++ b/src/i18n/de.po @@ -56,12 +56,12 @@ msgid "" "wallet." msgstr "" -#: src/webex/pages/confirm-contract.tsx:249 +#: src/webex/pages/confirm-contract.tsx:251 #, c-format msgid "The merchant%1$s offers you to purchase:\n" msgstr "" -#: src/webex/pages/confirm-contract.tsx:270 +#: src/webex/pages/confirm-contract.tsx:272 #, fuzzy, c-format msgid "Confirm payment" msgstr "Bezahlung bestätigen" diff --git a/src/i18n/en-US.po b/src/i18n/en-US.po index 3e47e952a..2fdb451db 100644 --- a/src/i18n/en-US.po +++ b/src/i18n/en-US.po @@ -56,12 +56,12 @@ msgid "" "wallet." msgstr "" -#: src/webex/pages/confirm-contract.tsx:249 +#: src/webex/pages/confirm-contract.tsx:251 #, c-format msgid "The merchant%1$s offers you to purchase:\n" msgstr "" -#: src/webex/pages/confirm-contract.tsx:270 +#: src/webex/pages/confirm-contract.tsx:272 #, c-format msgid "Confirm payment" msgstr "" diff --git a/src/i18n/fr.po b/src/i18n/fr.po index 97ff47067..5d47a1f74 100644 --- a/src/i18n/fr.po +++ b/src/i18n/fr.po @@ -56,12 +56,12 @@ msgid "" "wallet." msgstr "" -#: src/webex/pages/confirm-contract.tsx:249 +#: src/webex/pages/confirm-contract.tsx:251 #, c-format msgid "The merchant%1$s offers you to purchase:\n" msgstr "" -#: src/webex/pages/confirm-contract.tsx:270 +#: src/webex/pages/confirm-contract.tsx:272 #, c-format msgid "Confirm payment" msgstr "" diff --git a/src/i18n/it.po b/src/i18n/it.po index 97ff47067..5d47a1f74 100644 --- a/src/i18n/it.po +++ b/src/i18n/it.po @@ -56,12 +56,12 @@ msgid "" "wallet." msgstr "" -#: src/webex/pages/confirm-contract.tsx:249 +#: src/webex/pages/confirm-contract.tsx:251 #, c-format msgid "The merchant%1$s offers you to purchase:\n" msgstr "" -#: src/webex/pages/confirm-contract.tsx:270 +#: src/webex/pages/confirm-contract.tsx:272 #, c-format msgid "Confirm payment" msgstr "" diff --git a/src/i18n/taler-wallet-webex.pot b/src/i18n/taler-wallet-webex.pot index 97ff47067..5d47a1f74 100644 --- a/src/i18n/taler-wallet-webex.pot +++ b/src/i18n/taler-wallet-webex.pot @@ -56,12 +56,12 @@ msgid "" "wallet." msgstr "" -#: src/webex/pages/confirm-contract.tsx:249 +#: src/webex/pages/confirm-contract.tsx:251 #, c-format msgid "The merchant%1$s offers you to purchase:\n" msgstr "" -#: src/webex/pages/confirm-contract.tsx:270 +#: src/webex/pages/confirm-contract.tsx:272 #, c-format msgid "Confirm payment" msgstr "" diff --git a/src/query.ts b/src/query.ts index 290d02a2a..e45596c66 100644 --- a/src/query.ts +++ b/src/query.ts @@ -685,7 +685,6 @@ export class QueryRoot { put(store: Store, val: T, keyName?: string): QueryRoot { this.checkFinished(); const doPut = (tx: IDBTransaction) => { - console.log("put into", store.name, "value", val); const req = tx.objectStore(store.name).put(val); if (keyName) { req.onsuccess = () => { diff --git a/src/wallet.ts b/src/wallet.ts index aa974369a..7c2914926 100644 --- a/src/wallet.ts +++ b/src/wallet.ts @@ -96,6 +96,7 @@ import { CreateReserveRequest, CreateReserveResponse, HistoryRecord, + NextUrlResult, Notifier, PayCoinInfo, QueryPaymentResult, @@ -312,7 +313,7 @@ export class Wallet { private processPreCoinThrottle: {[url: string]: number} = {}; private timerGroup: TimerGroup; private speculativePayData: SpeculativePayData | undefined; - private cachedNextUrl: { [fulfillmentUrl: string]: string } = {}; + private cachedNextUrl: { [fulfillmentUrl: string]: NextUrlResult } = {}; /** * Set of identifiers for running operations. @@ -652,6 +653,7 @@ export class Wallet { contractTermsHash: proposal.contractTermsHash, finished: false, lastSessionSig: undefined, + lastSessionId: undefined, merchantSig: proposal.merchantSig, payReq, refundsDone: {}, @@ -735,14 +737,14 @@ export class Wallet { const fu = new URI(purchase.contractTerms.fulfillment_url); fu.addSearch("order_id", purchase.contractTerms.order_id); if (merchantResp.session_sig) { - fu.addSearch("session_sig", merchantResp.session_sig); purchase.lastSessionSig = merchantResp.session_sig; - console.log("updating session sig", purchase); + purchase.lastSessionId = sessionId; + fu.addSearch("session_sig", merchantResp.session_sig); await this.q().put(Stores.purchases, purchase).finish(); } await this.paymentSucceeded(purchase.contractTermsHash, merchantResp.sig); const nextUrl = fu.href(); - this.cachedNextUrl[purchase.contractTerms.fulfillment_url] = nextUrl; + this.cachedNextUrl[purchase.contractTerms.fulfillment_url] = { nextUrl, lastSessionId: sessionId }; return { nextUrl }; } @@ -899,6 +901,7 @@ export class Wallet { contractTerms: t.contractTerms, contractTermsHash: t.contractTermsHash, found: true, + lastSessionId: t.lastSessionId, lastSessionSig: t.lastSessionSig, payReq: t.payReq, }; @@ -925,6 +928,7 @@ export class Wallet { contractTermsHash: t.contractTermsHash, found: true, lastSessionSig: t.lastSessionSig, + lastSessionId: t.lastSessionId, payReq: t.payReq, }; } @@ -2891,7 +2895,7 @@ export class Wallet { * payed for, or if it is not cached anymore. Use the asynchronous * queryPaymentByFulfillmentUrl to avoid false negatives. */ - getNextUrlFromResourceUrl(resourceUrl: string): string | undefined { + getNextUrlFromResourceUrl(resourceUrl: string): NextUrlResult | undefined { return this.cachedNextUrl[resourceUrl]; } diff --git a/src/walletTypes.ts b/src/walletTypes.ts index 45a795873..c98717ac2 100644 --- a/src/walletTypes.ts +++ b/src/walletTypes.ts @@ -302,6 +302,7 @@ export interface QueryPaymentFound { contractTermsHash: string; contractTerms: ContractTerms; lastSessionSig?: string; + lastSessionId?: string; payReq: PayReq; } @@ -603,3 +604,12 @@ export interface Badge { */ clearNotification(): void; } + + +/** + * Cached next URL for a particular session id. + */ +export interface NextUrlResult { + nextUrl: string; + lastSessionId: string | undefined; +} diff --git a/src/webex/pages/confirm-contract.tsx b/src/webex/pages/confirm-contract.tsx index c302239c6..cd58d712a 100644 --- a/src/webex/pages/confirm-contract.tsx +++ b/src/webex/pages/confirm-contract.tsx @@ -150,7 +150,7 @@ class ContractPrompt extends React.Component