/* This file is part of TALER (C) 2016 GNUnet e.V. TALER is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version. TALER is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with TALER; see the file COPYING. If not, see */ /** * Interface to the wallet through WebExtension messaging. */ /** * Imports. */ import { AmountJson, ConfirmPayResult, BalancesResponse, PurchaseDetails, TipStatus, BenchmarkResult, PreparePayResult, AcceptWithdrawalResponse, WalletDiagnostics, CoreApiResponse, OperationFailedError, GetWithdrawalDetailsForUriRequest, WithdrawUriInfoResponse, TransactionsResponse, } from "taler-wallet-core"; export interface ExtendedPermissionsResponse { newValue: boolean; } /** * Response with information about available version upgrades. */ export interface UpgradeResponse { /** * Is a reset required because of a new DB version * that can't be atomatically upgraded? */ dbResetRequired: boolean; /** * Current database version. */ currentDbVersion: string; /** * Old db version (if applicable). */ oldDbVersion: string; } async function callBackend(operation: string, payload: any): Promise { return new Promise((resolve, reject) => { chrome.runtime.sendMessage({ operation, payload, id: "(none)" }, (resp) => { if (chrome.runtime.lastError) { console.log("Error calling backend"); reject( new Error( `Error contacting backend: chrome.runtime.lastError.message`, ), ); } console.log("got response", resp); const r = resp as CoreApiResponse; if (r.type === "error") { reject(new OperationFailedError(r.error)); return; } resolve(r.result); }); }); } /** * Start refreshing a coin. */ export function refresh(coinPub: string): Promise { return callBackend("refresh-coin", { coinPub }); } /** * Pay for a proposal. */ export function confirmPay( proposalId: string, sessionId: string | undefined, ): Promise { return callBackend("confirmPay", { proposalId, sessionId }); } /** * Check upgrade information */ export function checkUpgrade(): Promise { return callBackend("check-upgrade", {}); } /** * Reset database */ export function resetDb(): Promise { return callBackend("reset-db", {}); } /** * Get balances for all currencies/exchanges. */ export function getBalance(): Promise { return callBackend("getBalances", {}); } /** * Get balances for all currencies/exchanges. */ export function getTransactions(): Promise { return callBackend("getTransactions", {}); } /** * Return coins to a bank account. */ export function returnCoins(args: { amount: AmountJson; exchange: string; senderWire: string; }): Promise { return callBackend("return-coins", args); } /** * Look up a purchase in the wallet database from * the contract terms hash. */ export function getPurchaseDetails( proposalId: string, ): Promise { return callBackend("get-purchase-details", { proposalId }); } /** * Get the status of processing a tip. */ export function getTipStatus(talerTipUri: string): Promise { return callBackend("get-tip-status", { talerTipUri }); } /** * Mark a tip as accepted by the user. */ export function acceptTip(talerTipUri: string): Promise { return callBackend("accept-tip", { talerTipUri }); } /** * Download a refund and accept it. */ export function applyRefund( refundUrl: string, ): Promise<{ contractTermsHash: string; proposalId: string }> { return callBackend("accept-refund", { refundUrl }); } /** * Abort a failed payment and try to get a refund. */ export function abortFailedPayment(contractTermsHash: string): Promise { return callBackend("abort-failed-payment", { contractTermsHash }); } /** * Abort a failed payment and try to get a refund. */ export function benchmarkCrypto(repetitions: number): Promise { return callBackend("benchmark-crypto", { repetitions }); } /** * Get details about a pay operation. */ export function preparePay(talerPayUri: string): Promise { return callBackend("preparePay", { talerPayUri }); } /** * Get details about a withdraw operation. */ export function acceptWithdrawal( talerWithdrawUri: string, selectedExchange: string, ): Promise { return callBackend("acceptBankIntegratedWithdrawal", { talerWithdrawUri, exchangeBaseUrl: selectedExchange, }); } /** * Get diagnostics information */ export function getDiagnostics(): Promise { return callBackend("get-diagnostics", {}); } /** * Get diagnostics information */ export function setExtendedPermissions( value: boolean, ): Promise { return callBackend("set-extended-permissions", { value }); } /** * Get diagnostics information */ export function getExtendedPermissions(): Promise { return callBackend("get-extended-permissions", {}); } /** * Get diagnostics information */ export function getWithdrawalDetailsForUri( req: GetWithdrawalDetailsForUriRequest, ): Promise { return callBackend("getWithdrawalDetailsForUri", req); } export function onUpdateNotification(f: () => void): () => void { const port = chrome.runtime.connect({ name: "notifications" }); const listener = (): void => { f(); }; port.onMessage.addListener(listener); return () => { port.onMessage.removeListener(listener); }; }