diff --git a/extension/background/main.ts b/extension/background/main.ts
index 7d607aa49..5fdee658e 100644
--- a/extension/background/main.ts
+++ b/extension/background/main.ts
@@ -20,16 +20,22 @@
"use strict";
+// TypeScript does not allow ".js" extensions in the
+// module name, so SystemJS must add it.
System.config({
defaultJSExtensions: true,
});
-var Module: any;
-
+// We expect that in the manifest, the emscripten js is loaded
+// becore the background page.
+// Currently it is not possible to use SystemJS to load the emscripten js.
+declare var Module: any;
if ("object" !== typeof Module) {
throw Error("emscripten not loaded, no 'Module' defined");
}
+// Manually register the emscripten js as a SystemJS, so that
+// we can use it from TypeScript by importing it.
let mod = System.newModule({Module: Module});
let modName = System.normalizeSync("../lib/emscripten/emsc");
console.log("registering", modName);
diff --git a/extension/content_scripts/notify.js b/extension/content_scripts/notify.js
index 7791f86e1..e99dabc32 100644
--- a/extension/content_scripts/notify.js
+++ b/extension/content_scripts/notify.js
@@ -14,11 +14,11 @@
TALER; see the file COPYING. If not, If not, see
*/
///
+"use strict";
/**
* Script that is injected into (all!) pages to allow them
* to interact with the GNU Taler wallet via DOM Events.
*/
-"use strict";
// Make sure we don't pollute the namespace too much.
var TalerNotify;
(function (TalerNotify) {
diff --git a/extension/content_scripts/notify.ts b/extension/content_scripts/notify.ts
index c2dd5ab64..47f57b6a0 100644
--- a/extension/content_scripts/notify.ts
+++ b/extension/content_scripts/notify.ts
@@ -16,14 +16,14 @@
///
+"use strict";
+
+
/**
* Script that is injected into (all!) pages to allow them
* to interact with the GNU Taler wallet via DOM Events.
*/
-
-"use strict";
-
// Make sure we don't pollute the namespace too much.
namespace TalerNotify {
const PROTOCOL_VERSION = 1;
diff --git a/extension/gulpfile.js b/extension/gulpfile.js
index 9981de939..8017df684 100644
--- a/extension/gulpfile.js
+++ b/extension/gulpfile.js
@@ -71,6 +71,8 @@ const tsBaseArgs = {
module: "system",
sourceMap: true,
noLib: true,
+ noImplicitReturns: true,
+ noFallthroughCasesInSwitch: true,
};
diff --git a/extension/lib/mithril.d.ts b/extension/lib/decl/mithril.d.ts
similarity index 100%
rename from extension/lib/mithril.d.ts
rename to extension/lib/decl/mithril.d.ts
diff --git a/extension/lib/wallet/emscriptif.ts b/extension/lib/wallet/emscriptif.ts
index b11d845f0..16c883451 100644
--- a/extension/lib/wallet/emscriptif.ts
+++ b/extension/lib/wallet/emscriptif.ts
@@ -14,7 +14,7 @@
TALER; see the file COPYING. If not, If not, see
*/
-import {AmountJson} from "./types";
+import {AmountJson} from "./wallet";
import * as EmscWrapper from "../emscripten/emsc";
/**
diff --git a/extension/lib/wallet/types.ts b/extension/lib/wallet/types.ts
deleted file mode 100644
index 4f512800e..000000000
--- a/extension/lib/wallet/types.ts
+++ /dev/null
@@ -1,200 +0,0 @@
-/*
- 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, If not, see
- */
-
-import {EddsaPublicKey} from "./emscriptif";
-import {Checkable} from "./checkable";
-"use strict";
-
-// TODO: factor into multiple files
-
-export interface Mint {
- baseUrl: string;
- keys: Keys
-}
-
-export interface CoinWithDenom {
- coin: Coin;
- denom: Denomination;
-}
-
-export interface Keys {
- denoms: Denomination[];
-}
-
-export interface Denomination {
- value: AmountJson;
- denom_pub: string;
- fee_withdraw: AmountJson;
- fee_deposit: AmountJson;
-}
-
-export interface PreCoin {
- coinPub: string;
- coinPriv: string;
- reservePub: string;
- denomPub: string;
- blindingKey: string;
- withdrawSig: string;
- coinEv: string;
- mintBaseUrl: string;
- coinValue: AmountJson;
-}
-
-export interface Coin {
- coinPub: string;
- coinPriv: string;
- denomPub: string;
- denomSig: string;
- currentAmount: AmountJson;
- mintBaseUrl: string;
-}
-
-
-@Checkable.Class
-export class AmountJson {
- @Checkable.Number
- value: number;
-
- @Checkable.Number
- fraction: number;
-
- @Checkable.String
- currency: string;
-
- static checked: (obj: any) => AmountJson;
-}
-
-
-@Checkable.Class
-export class CreateReserveRequest {
- /**
- * The initial amount for the reserve.
- */
- @Checkable.Value(AmountJson)
- amount: AmountJson;
-
- /**
- * Mint URL where the bank should create the reserve.
- */
- @Checkable.String
- mint: string;
-
- static checked: (obj: any) => CreateReserveRequest;
-}
-
-
-@Checkable.Class
-export class CreateReserveResponse {
- /**
- * Mint URL where the bank should create the reserve.
- * The URL is canonicalized in the response.
- */
- @Checkable.String
- mint: string;
-
- @Checkable.String
- reservePub: string;
-
- static checked: (obj: any) => CreateReserveResponse;
-}
-
-
-@Checkable.Class
-export class ConfirmReserveRequest {
- /**
- * Public key of then reserve that should be marked
- * as confirmed.
- */
- @Checkable.String
- reservePub: string;
-
- static checked: (obj: any) => ConfirmReserveRequest;
-}
-
-
-@Checkable.Class
-export class MintInfo {
- @Checkable.String
- master_pub: string;
-
- @Checkable.String
- url: string;
-
- static checked: (obj: any) => MintInfo;
-}
-
-
-@Checkable.Class
-export class Contract {
- @Checkable.String
- H_wire: string;
-
- @Checkable.Value(AmountJson)
- amount: AmountJson;
-
- @Checkable.List(Checkable.AnyObject)
- auditors: any[];
-
- @Checkable.String
- expiry: string;
-
- @Checkable.Any
- locations: any;
-
- @Checkable.Value(AmountJson)
- max_fee: AmountJson;
-
- @Checkable.Any
- merchant: any;
-
- @Checkable.String
- merchant_pub: string;
-
- @Checkable.List(Checkable.Value(MintInfo))
- mints: MintInfo[];
-
- @Checkable.List(Checkable.AnyObject)
- products: any[];
-
- @Checkable.String
- refund_deadline: string;
-
- @Checkable.String
- timestamp: string;
-
- @Checkable.Number
- transaction_id: number;
-
- @Checkable.String
- fulfillment_url: string;
-
- static checked: (obj: any) => Contract;
-}
-
-
-@Checkable.Class
-export class Offer {
- @Checkable.Value(Contract)
- contract: Contract;
-
- @Checkable.String
- merchant_sig: string;
-
- @Checkable.String
- H_contract: string;
-
- static checked: (obj: any) => Offer;
-}
\ No newline at end of file
diff --git a/extension/lib/wallet/wallet.ts b/extension/lib/wallet/wallet.ts
index 62d67b40c..0a9fbe191 100644
--- a/extension/lib/wallet/wallet.ts
+++ b/extension/lib/wallet/wallet.ts
@@ -21,41 +21,195 @@
* @author Florian Dold
*/
-import {Amount} from "./emscriptif"
-import {CoinWithDenom} from "./types";
-import {DepositRequestPS_Args} from "./emscriptif";
-import {HashCode} from "./emscriptif";
-import {EddsaPublicKey} from "./emscriptif";
-import {Coin} from "./types";
-import {AbsoluteTimeNbo} from "./emscriptif";
-import {UInt64} from "./emscriptif";
-import {DepositRequestPS} from "./emscriptif";
-import {eddsaSign} from "./emscriptif";
-import {EddsaPrivateKey} from "./emscriptif";
-import {CreateReserveRequest} from "./types";
-import {RsaPublicKey} from "./emscriptif";
-import {Denomination} from "./types";
-import {RsaBlindingKey} from "./emscriptif";
-import {ByteArray} from "./emscriptif";
-import {rsaBlind} from "./emscriptif";
-import {WithdrawRequestPS} from "./emscriptif";
-import {PreCoin} from "./types";
-import {rsaUnblind} from "./emscriptif";
-import {RsaSignature} from "./emscriptif";
-import {Mint} from "./types";
-import {HttpResponse} from "./http";
-import {RequestException} from "./http";
+import * as native from "./emscriptif";
+import {HttpResponse, RequestException} from "./http";
import {Query} from "./query";
-import {AmountJson} from "./types";
-import {ConfirmReserveRequest} from "./types";
-import {Offer} from "./types";
-import {Contract} from "./types";
-import {MintInfo} from "./types";
-import {CreateReserveResponse} from "./types";
+import {Checkable} from "./checkable";
"use strict";
+export interface Mint {
+ baseUrl: string;
+ keys: Keys
+}
+
+export interface CoinWithDenom {
+ coin: Coin;
+ denom: Denomination;
+}
+
+export interface Keys {
+ denoms: Denomination[];
+}
+
+export interface Denomination {
+ value: AmountJson;
+ denom_pub: string;
+ fee_withdraw: AmountJson;
+ fee_deposit: AmountJson;
+ stamp_expire_withdraw: string;
+}
+
+export interface PreCoin {
+ coinPub: string;
+ coinPriv: string;
+ reservePub: string;
+ denomPub: string;
+ blindingKey: string;
+ withdrawSig: string;
+ coinEv: string;
+ mintBaseUrl: string;
+ coinValue: AmountJson;
+}
+
+export interface Coin {
+ coinPub: string;
+ coinPriv: string;
+ denomPub: string;
+ denomSig: string;
+ currentAmount: AmountJson;
+ mintBaseUrl: string;
+}
+
+
+@Checkable.Class
+export class AmountJson {
+ @Checkable.Number
+ value: number;
+
+ @Checkable.Number
+ fraction: number;
+
+ @Checkable.String
+ currency: string;
+
+ static checked: (obj: any) => AmountJson;
+}
+
+
+@Checkable.Class
+export class CreateReserveRequest {
+ /**
+ * The initial amount for the reserve.
+ */
+ @Checkable.Value(AmountJson)
+ amount: AmountJson;
+
+ /**
+ * Mint URL where the bank should create the reserve.
+ */
+ @Checkable.String
+ mint: string;
+
+ static checked: (obj: any) => CreateReserveRequest;
+}
+
+
+@Checkable.Class
+export class CreateReserveResponse {
+ /**
+ * Mint URL where the bank should create the reserve.
+ * The URL is canonicalized in the response.
+ */
+ @Checkable.String
+ mint: string;
+
+ @Checkable.String
+ reservePub: string;
+
+ static checked: (obj: any) => CreateReserveResponse;
+}
+
+
+@Checkable.Class
+export class ConfirmReserveRequest {
+ /**
+ * Public key of then reserve that should be marked
+ * as confirmed.
+ */
+ @Checkable.String
+ reservePub: string;
+
+ static checked: (obj: any) => ConfirmReserveRequest;
+}
+
+
+@Checkable.Class
+export class MintInfo {
+ @Checkable.String
+ master_pub: string;
+
+ @Checkable.String
+ url: string;
+
+ static checked: (obj: any) => MintInfo;
+}
+
+
+@Checkable.Class
+export class Contract {
+ @Checkable.String
+ H_wire: string;
+
+ @Checkable.Value(AmountJson)
+ amount: AmountJson;
+
+ @Checkable.List(Checkable.AnyObject)
+ auditors: any[];
+
+ @Checkable.String
+ expiry: string;
+
+ @Checkable.Any
+ locations: any;
+
+ @Checkable.Value(AmountJson)
+ max_fee: AmountJson;
+
+ @Checkable.Any
+ merchant: any;
+
+ @Checkable.String
+ merchant_pub: string;
+
+ @Checkable.List(Checkable.Value(MintInfo))
+ mints: MintInfo[];
+
+ @Checkable.List(Checkable.AnyObject)
+ products: any[];
+
+ @Checkable.String
+ refund_deadline: string;
+
+ @Checkable.String
+ timestamp: string;
+
+ @Checkable.Number
+ transaction_id: number;
+
+ @Checkable.String
+ fulfillment_url: string;
+
+ static checked: (obj: any) => Contract;
+}
+
+
+@Checkable.Class
+export class Offer {
+ @Checkable.Value(Contract)
+ contract: Contract;
+
+ @Checkable.String
+ merchant_sig: string;
+
+ @Checkable.String
+ H_contract: string;
+
+ static checked: (obj: any) => Offer;
+}
+
+
interface ConfirmPayRequest {
offer: Offer;
}
@@ -93,10 +247,29 @@ export interface Badge {
setColor(c: string): void;
}
-
type PayCoinInfo = Array<{ updatedCoin: Coin, sig: CoinPaySig }>;
+function getTalerStampSec(stamp: string) {
+ const m = stamp.match(/\/?Date\(([0-9]*)\)\/?/);
+ if (!m) {
+ return null;
+ }
+ return parseInt(m[1]);
+}
+
+
+function isWithdrawableDenom(d: Denomination) {
+ const now_sec = (new Date).getTime() / 1000;
+ const stamp_withdraw_sec = getTalerStampSec(d.stamp_expire_withdraw);
+ // Withdraw if still possible to withdraw within a minute
+ if (stamp_withdraw_sec + 60 > now_sec) {
+ return true;
+ }
+ return false;
+}
+
+
/**
* See http://api.taler.net/wallet.html#general
*/
@@ -111,6 +284,7 @@ function canonicalizeBaseUrl(url) {
return x.href()
}
+
function parsePrettyAmount(pretty: string): AmountJson {
const res = /([0-9]+)(.[0-9]+)?\s*(\w+)/.exec(pretty);
if (!res) {
@@ -144,8 +318,8 @@ function copy(o) {
function rankDenom(denom1: any, denom2: any) {
// Slow ... we should find a better way than to convert it evert time.
- let v1 = new Amount(denom1.value);
- let v2 = new Amount(denom2.value);
+ let v1 = new native.Amount(denom1.value);
+ let v2 = new native.Amount(denom2.value);
return (-1) * v1.cmp(v2);
}
@@ -161,11 +335,11 @@ export class Wallet {
this.badge = badge;
}
- static signDeposit(offer: Offer,
- cds: CoinWithDenom[]): PayCoinInfo {
+ private static signDeposit(offer: Offer,
+ cds: CoinWithDenom[]): PayCoinInfo {
let ret = [];
- let amountSpent = Amount.getZero(cds[0].coin.currentAmount.currency);
- let amountRemaining = new Amount(offer.contract.amount);
+ let amountSpent = native.Amount.getZero(cds[0].coin.currentAmount.currency);
+ let amountRemaining = new native.Amount(offer.contract.amount);
cds = copy(cds);
for (let cd of cds) {
let coinSpend;
@@ -174,36 +348,36 @@ export class Wallet {
break;
}
- if (amountRemaining.cmp(new Amount(cd.coin.currentAmount)) < 0) {
- coinSpend = new Amount(amountRemaining.toJson());
+ if (amountRemaining.cmp(new native.Amount(cd.coin.currentAmount)) < 0) {
+ coinSpend = new native.Amount(amountRemaining.toJson());
} else {
- coinSpend = new Amount(cd.coin.currentAmount);
+ coinSpend = new native.Amount(cd.coin.currentAmount);
}
amountSpent.add(coinSpend);
amountRemaining.sub(coinSpend);
- let newAmount = new Amount(cd.coin.currentAmount);
+ let newAmount = new native.Amount(cd.coin.currentAmount);
newAmount.sub(coinSpend);
cd.coin.currentAmount = newAmount.toJson();
- let args: DepositRequestPS_Args = {
- h_contract: HashCode.fromCrock(offer.H_contract),
- h_wire: HashCode.fromCrock(offer.contract.H_wire),
+ let args: native.DepositRequestPS_Args = {
+ h_contract: native.HashCode.fromCrock(offer.H_contract),
+ h_wire: native.HashCode.fromCrock(offer.contract.H_wire),
amount_with_fee: coinSpend.toNbo(),
- coin_pub: EddsaPublicKey.fromCrock(cd.coin.coinPub),
- deposit_fee: new Amount(cd.denom.fee_deposit).toNbo(),
- merchant: EddsaPublicKey.fromCrock(offer.contract.merchant_pub),
- refund_deadline: AbsoluteTimeNbo.fromTalerString(offer.contract.refund_deadline),
- timestamp: AbsoluteTimeNbo.fromTalerString(offer.contract.timestamp),
- transaction_id: UInt64.fromNumber(offer.contract.transaction_id),
+ coin_pub: native.EddsaPublicKey.fromCrock(cd.coin.coinPub),
+ deposit_fee: new native.Amount(cd.denom.fee_deposit).toNbo(),
+ merchant: native.EddsaPublicKey.fromCrock(offer.contract.merchant_pub),
+ refund_deadline: native.AbsoluteTimeNbo.fromTalerString(offer.contract.refund_deadline),
+ timestamp: native.AbsoluteTimeNbo.fromTalerString(offer.contract.timestamp),
+ transaction_id: native.UInt64.fromNumber(offer.contract.transaction_id),
};
- let d = new DepositRequestPS(args);
+ let d = new native.DepositRequestPS(args);
- let coinSig = eddsaSign(d.toPurpose(),
- EddsaPrivateKey.fromCrock(cd.coin.coinPriv))
- .toCrock();
+ let coinSig = native.eddsaSign(d.toPurpose(),
+ native.EddsaPrivateKey.fromCrock(cd.coin.coinPriv))
+ .toCrock();
let s: CoinPaySig = {
coin_sig: coinSig,
@@ -225,9 +399,9 @@ export class Wallet {
* @param depositFeeLimit
* @param allowedMints
*/
- getPossibleMintCoins(paymentAmount: AmountJson,
- depositFeeLimit: AmountJson,
- allowedMints: MintInfo[]): Promise {
+ private getPossibleMintCoins(paymentAmount: AmountJson,
+ depositFeeLimit: AmountJson,
+ allowedMints: MintInfo[]): Promise {
let m: MintCoins = {};
@@ -263,19 +437,19 @@ export class Wallet {
nextMint:
for (let key in m) {
let coins = m[key].map((x) => ({
- a: new Amount(x.denom.fee_deposit),
+ a: new native.Amount(x.denom.fee_deposit),
c: x
}));
// Sort by ascending deposit fee
coins.sort((o1, o2) => o1.a.cmp(o2.a));
- let maxFee = new Amount(depositFeeLimit);
- let minAmount = new Amount(paymentAmount);
- let accFee = new Amount(coins[0].c.denom.fee_deposit);
- let accAmount = Amount.getZero(coins[0].c.coin.currentAmount.currency);
+ let maxFee = new native.Amount(depositFeeLimit);
+ let minAmount = new native.Amount(paymentAmount);
+ let accFee = new native.Amount(coins[0].c.denom.fee_deposit);
+ let accAmount = native.Amount.getZero(coins[0].c.coin.currentAmount.currency);
let usableCoins: CoinWithDenom[] = [];
nextCoin:
for (let i = 0; i < coins.length; i++) {
- let coinAmount = new Amount(coins[i].c.coin.currentAmount);
+ let coinAmount = new native.Amount(coins[i].c.coin.currentAmount);
let coinFee = coins[i].a;
if (coinAmount.cmp(coinFee) <= 0) {
continue nextCoin;
@@ -298,9 +472,13 @@ export class Wallet {
}
- executePay(offer: Offer,
- payCoinInfo: PayCoinInfo,
- chosenMint: string): Promise {
+ /**
+ * Record all information that is necessary to
+ * pay for a contract in the wallet's database.
+ */
+ private recordConfirmPay(offer: Offer,
+ payCoinInfo: PayCoinInfo,
+ chosenMint: string): Promise {
let payReq = {};
payReq["amount"] = offer.contract.amount;
payReq["coins"] = payCoinInfo.map((x) => x.sig);
@@ -332,14 +510,14 @@ export class Wallet {
.put("transactions", t)
.put("history", historyEntry)
.putAll("coins", payCoinInfo.map((pci) => pci.updatedCoin))
- .finish()
- .then(() => {
- return {
- success: true
- };
- });
+ .finish();
}
+
+ /**
+ * Add a contract to the wallet and sign coins,
+ * but do not send them yet.
+ */
confirmPay(offer: Offer): Promise {
return Promise.resolve().then(() => {
return this.getPossibleMintCoins(offer.contract.amount,
@@ -348,18 +526,22 @@ export class Wallet {
}).then((mcs) => {
if (Object.keys(mcs).length == 0) {
return {
- success: false,
- message: "Not enough coins",
+ error: "coins-insufficient",
};
}
let mintUrl = Object.keys(mcs)[0];
let ds = Wallet.signDeposit(offer, mcs[mintUrl]);
- return this
- .executePay(offer, ds, mintUrl);
+ return this.recordConfirmPay(offer, ds, mintUrl)
+ .then((() => ({})));
});
}
- doPayment(H_contract): Promise {
+
+ /**
+ * Retrieve all necessary information for looking up the contract
+ * with the given hash.
+ */
+ executePayment(H_contract): Promise {
return Promise.resolve().then(() => {
return Query(this.db)
.get("transactions", H_contract)
@@ -385,7 +567,7 @@ export class Wallet {
* First fetch information requred to withdraw from the reserve,
* then deplete the reserve, withdrawing coins until it is empty.
*/
- initReserve(reserveRecord) {
+ private initReserve(reserveRecord) {
this.updateMintFromUrl(reserveRecord.mint_base_url)
.then((mint) =>
this.updateReserve(reserveRecord.reserve_pub, mint)
@@ -411,7 +593,7 @@ export class Wallet {
* Create a reserve, but do not flag it as confirmed yet.
*/
createReserve(req: CreateReserveRequest): Promise {
- const reservePriv = EddsaPrivateKey.create();
+ const reservePriv = native.EddsaPrivateKey.create();
const reservePub = reservePriv.getPublicKey();
const now = (new Date).getTime();
@@ -486,29 +668,31 @@ export class Wallet {
}
- withdrawPrepare(denom: Denomination,
- reserve: Reserve): Promise {
- let reservePriv = new EddsaPrivateKey();
+ private withdrawPrepare(denom: Denomination,
+ reserve: Reserve): Promise {
+ let reservePriv = new native.EddsaPrivateKey();
reservePriv.loadCrock(reserve.reserve_priv);
- let reservePub = new EddsaPublicKey();
+ let reservePub = new native.EddsaPublicKey();
reservePub.loadCrock(reserve.reserve_pub);
- let denomPub = RsaPublicKey.fromCrock(denom.denom_pub);
- let coinPriv = EddsaPrivateKey.create();
+ let denomPub = native.RsaPublicKey.fromCrock(denom.denom_pub);
+ let coinPriv = native.EddsaPrivateKey.create();
let coinPub = coinPriv.getPublicKey();
- let blindingFactor = RsaBlindingKey.create(1024);
- let pubHash: HashCode = coinPub.hash();
- let ev: ByteArray = rsaBlind(pubHash, blindingFactor, denomPub);
+ let blindingFactor = native.RsaBlindingKey.create(1024);
+ let pubHash: native.HashCode = coinPub.hash();
+ let ev: native.ByteArray = native.rsaBlind(pubHash,
+ blindingFactor,
+ denomPub);
if (!denom.fee_withdraw) {
throw Error("Field fee_withdraw missing");
}
- let amountWithFee = new Amount(denom.value);
- amountWithFee.add(new Amount(denom.fee_withdraw));
- let withdrawFee = new Amount(denom.fee_withdraw);
+ let amountWithFee = new native.Amount(denom.value);
+ amountWithFee.add(new native.Amount(denom.fee_withdraw));
+ let withdrawFee = new native.Amount(denom.fee_withdraw);
// Signature
- let withdrawRequest = new WithdrawRequestPS({
+ let withdrawRequest = new native.WithdrawRequestPS({
reserve_pub: reservePub,
amount_with_fee: amountWithFee.toNbo(),
withdraw_fee: withdrawFee.toNbo(),
@@ -516,7 +700,7 @@ export class Wallet {
h_coin_envelope: ev.hash()
});
- var sig = eddsaSign(withdrawRequest.toPurpose(), reservePriv);
+ var sig = native.eddsaSign(withdrawRequest.toPurpose(), reservePriv);
let preCoin: PreCoin = {
reservePub: reservePub.toCrock(),
@@ -534,7 +718,7 @@ export class Wallet {
}
- withdrawExecute(pc: PreCoin): Promise {
+ private withdrawExecute(pc: PreCoin): Promise {
return Query(this.db)
.get("reserves", pc.reservePub)
.then((r) => {
@@ -554,9 +738,9 @@ export class Wallet {
});
}
let r = JSON.parse(resp.responseText);
- let denomSig = rsaUnblind(RsaSignature.fromCrock(r.ev_sig),
- RsaBlindingKey.fromCrock(pc.blindingKey),
- RsaPublicKey.fromCrock(pc.denomPub));
+ let denomSig = native.rsaUnblind(native.RsaSignature.fromCrock(r.ev_sig),
+ native.RsaBlindingKey.fromCrock(pc.blindingKey),
+ native.RsaPublicKey.fromCrock(pc.denomPub));
let coin: Coin = {
coinPub: pc.coinPub,
coinPriv: pc.coinPriv,
@@ -609,7 +793,7 @@ export class Wallet {
}
- withdraw(denom, reserve): Promise {
+ private withdraw(denom, reserve): Promise {
return this.withdrawPrepare(denom, reserve)
.then((pc) => this.withdrawExecute(pc))
.then((c) => this.storeCoin(c));
@@ -619,16 +803,19 @@ export class Wallet {
/**
* Withdraw coins from a reserve until it is empty.
*/
- depleteReserve(reserve, mint): Promise {
- let denoms = copy(mint.keys.denoms);
- let remaining = new Amount(reserve.current_amount);
+ private depleteReserve(reserve, mint: Mint): Promise {
+ let denoms: Denomination[] = copy(mint.keys.denoms);
+ let remaining = new native.Amount(reserve.current_amount);
+
+ denoms = denoms.filter(isWithdrawableDenom);
+
denoms.sort(rankDenom);
let workList = [];
for (let i = 0; i < 1000; i++) {
let found = false;
for (let d of denoms) {
- let cost = new Amount(d.value);
- cost.add(new Amount(d.fee_withdraw));
+ let cost = new native.Amount(d.value);
+ cost.add(new native.Amount(d.fee_withdraw));
if (remaining.cmp(cost) < 0) {
continue;
}
@@ -665,8 +852,7 @@ export class Wallet {
}
- updateReserve(reservePub: string,
- mint): Promise {
+ private updateReserve(reservePub: string, mint): Promise {
return Query(this.db)
.get("reserves", reservePub)
.then((reserve) => {
@@ -706,7 +892,7 @@ export class Wallet {
* Optionally link the reserve entry to the new or existing
* mint entry in then DB.
*/
- updateMintFromUrl(baseUrl) {
+ private updateMintFromUrl(baseUrl): Promise {
let reqUrl = URI("keys").absoluteTo(baseUrl);
return this.http.get(reqUrl).then((resp) => {
if (resp.status != 200) {
@@ -729,10 +915,10 @@ export class Wallet {
function collectBalances(c: Coin, byCurrency) {
let acc: AmountJson = byCurrency[c.currentAmount.currency];
if (!acc) {
- acc = Amount.getZero(c.currentAmount.currency).toJson();
+ acc = native.Amount.getZero(c.currentAmount.currency).toJson();
}
- let am = new Amount(c.currentAmount);
- am.add(new Amount(acc));
+ let am = new native.Amount(c.currentAmount);
+ am.add(new native.Amount(acc));
byCurrency[c.currentAmount.currency] = am.toJson();
return byCurrency;
}
diff --git a/extension/lib/wallet/wxmessaging.js b/extension/lib/wallet/wxmessaging.js
index 1e1029be0..f5819b197 100644
--- a/extension/lib/wallet/wxmessaging.js
+++ b/extension/lib/wallet/wxmessaging.js
@@ -13,9 +13,10 @@
You should have received a copy of the GNU General Public License along with
TALER; see the file COPYING. If not, If not, see
*/
-System.register(["./types", "./wallet", "./db", "./http"], function(exports_1) {
+System.register(["./wallet", "./db", "./http"], function(exports_1, context_1) {
"use strict";
- var types_1, wallet_1, db_1, db_2, db_3, http_1, types_2, types_3;
+ var __moduleName = context_1 && context_1.id;
+ var wallet_1, db_1, http_1;
var ChromeBadge;
/**
* Messaging for the WebExtensions wallet. Should contain
@@ -44,7 +45,7 @@ System.register(["./types", "./wallet", "./db", "./http"], function(exports_1) {
for (var i = 0; i < db.objectStoreNames.length; i++) {
tx.objectStore(db.objectStoreNames[i]).clear();
}
- db_2.deleteDb();
+ db_1.deleteDb();
chrome.browserAction.setBadgeText({ text: "" });
console.log("reset done");
// Response is synchronous
@@ -55,7 +56,7 @@ System.register(["./types", "./wallet", "./db", "./http"], function(exports_1) {
mint: detail.mint,
amount: detail.amount,
};
- var req = types_2.CreateReserveRequest.checked(d);
+ var req = wallet_1.CreateReserveRequest.checked(d);
wallet.createReserve(req)
.then(function (resp) {
sendResponse(resp);
@@ -72,7 +73,7 @@ System.register(["./types", "./wallet", "./db", "./http"], function(exports_1) {
var d = {
reservePub: detail.reservePub
};
- var req = types_1.ConfirmReserveRequest.checked(d);
+ var req = wallet_1.ConfirmReserveRequest.checked(d);
wallet.confirmReserve(req)
.then(function (resp) {
sendResponse(resp);
@@ -85,10 +86,10 @@ System.register(["./types", "./wallet", "./db", "./http"], function(exports_1) {
return true;
},
_a["confirm-pay"] = function (db, detail, sendResponse) {
- var offer = types_3.Offer.checked(detail.offer);
+ var offer = wallet_1.Offer.checked(detail.offer);
wallet.confirmPay(offer)
- .then(function (r) {
- sendResponse(r);
+ .then(function () {
+ sendResponse({});
})
.catch(function (e) {
console.error("exception during 'confirm-pay'");
@@ -98,7 +99,7 @@ System.register(["./types", "./wallet", "./db", "./http"], function(exports_1) {
return true;
},
_a["execute-payment"] = function (db, detail, sendResponse) {
- wallet.doPayment(detail.H_contract)
+ wallet.executePayment(detail.H_contract)
.then(function (r) {
sendResponse(r);
})
@@ -131,7 +132,7 @@ System.register(["./types", "./wallet", "./db", "./http"], function(exports_1) {
}
function wxMain() {
chrome.browserAction.setBadgeText({ text: "" });
- db_3.openTalerDb()
+ db_1.openTalerDb()
.then(function (db) {
var http = new http_1.BrowserHttpLib();
var badge = new ChromeBadge();
@@ -154,18 +155,11 @@ System.register(["./types", "./wallet", "./db", "./http"], function(exports_1) {
exports_1("wxMain", wxMain);
return {
setters:[
- function (types_1_1) {
- types_1 = types_1_1;
- types_2 = types_1_1;
- types_3 = types_1_1;
- },
function (wallet_1_1) {
wallet_1 = wallet_1_1;
},
function (db_1_1) {
db_1 = db_1_1;
- db_2 = db_1_1;
- db_3 = db_1_1;
},
function (http_1_1) {
http_1 = http_1_1;
diff --git a/extension/lib/wallet/wxmessaging.ts b/extension/lib/wallet/wxmessaging.ts
index 9af63eb2f..045145716 100644
--- a/extension/lib/wallet/wxmessaging.ts
+++ b/extension/lib/wallet/wxmessaging.ts
@@ -15,15 +15,9 @@
*/
-import {ConfirmReserveRequest} from "./types";
-import {Wallet} from "./wallet";
-import {exportDb} from "./db";
-import {deleteDb} from "./db";
-import {openTalerDb} from "./db";
+import {Wallet, Offer, Badge, ConfirmReserveRequest, CreateReserveRequest} from "./wallet";
+import {deleteDb, exportDb, openTalerDb} from "./db";
import {BrowserHttpLib} from "./http";
-import {Badge} from "./wallet";
-import {CreateReserveRequest} from "./types";
-import {Offer} from "./types";
"use strict";
@@ -99,8 +93,8 @@ function makeHandlers(wallet: Wallet) {
["confirm-pay"]: function(db, detail, sendResponse) {
const offer = Offer.checked(detail.offer);
wallet.confirmPay(offer)
- .then((r) => {
- sendResponse(r)
+ .then(() => {
+ sendResponse({})
})
.catch((e) => {
console.error("exception during 'confirm-pay'");
@@ -110,7 +104,7 @@ function makeHandlers(wallet: Wallet) {
return true;
},
["execute-payment"]: function(db, detail, sendResponse) {
- wallet.doPayment(detail.H_contract)
+ wallet.executePayment(detail.H_contract)
.then((r) => {
sendResponse(r);
})
diff --git a/extension/lib/web-common.ts b/extension/lib/web-common.ts
index 96f9b61b7..79ff4b13e 100644
--- a/extension/lib/web-common.ts
+++ b/extension/lib/web-common.ts
@@ -14,7 +14,8 @@
TALER; see the file COPYING. If not, If not, see
*/
-import {AmountJson} from "./wallet/types";
+import {AmountJson} from "./wallet/wallet";
+
export function substituteFulfillmentUrl(url: string, vars) {
url = url.replace("${H_contract}", vars.H_contract);
url = url.replace("${$}", "$");
diff --git a/extension/manifest.json b/extension/manifest.json
index b228cc0cc..1eeeea6a6 100644
--- a/extension/manifest.json
+++ b/extension/manifest.json
@@ -2,7 +2,7 @@
"description": "Privacy preserving and transparent payments",
"manifest_version": 2,
"name": "GNU Taler Wallet (git)",
- "version": "0.5.5",
+ "version": "0.5.6",
"applications": {
"gecko": {
diff --git a/extension/pages/confirm-contract.js b/extension/pages/confirm-contract.js
index 70ecff399..d715985b5 100644
--- a/extension/pages/confirm-contract.js
+++ b/extension/pages/confirm-contract.js
@@ -13,9 +13,10 @@
You should have received a copy of the GNU General Public License along with
TALER; see the file COPYING. If not, If not, see
*/
-System.register(["../lib/web-common"], function(exports_1) {
+System.register(["../lib/web-common"], function(exports_1, context_1) {
///
"use strict";
+ var __moduleName = context_1 && context_1.id;
var web_common_1;
function prettyAmount(amount) {
var v = amount.value + amount.fraction / 1e6;
diff --git a/extension/pages/confirm-create-reserve.js b/extension/pages/confirm-create-reserve.js
index a53833f04..3ac757249 100644
--- a/extension/pages/confirm-create-reserve.js
+++ b/extension/pages/confirm-create-reserve.js
@@ -13,14 +13,15 @@
You should have received a copy of the GNU General Public License along with
TALER; see the file COPYING. If not, If not, see
*/
-System.register(["../lib/wallet/types", "../lib/web-common"], function(exports_1) {
+System.register(["../lib/web-common", "../lib/wallet/wallet"], function(exports_1, context_1) {
"use strict";
- var types_1, web_common_1, types_2;
+ var __moduleName = context_1 && context_1.id;
+ var web_common_1, wallet_1;
function main() {
function updateAmount() {
var showAmount = document.getElementById("show-amount");
console.log("Query is " + JSON.stringify(query));
- var amount = types_1.AmountJson.checked(JSON.parse(query.amount));
+ var amount = wallet_1.AmountJson.checked(JSON.parse(query.amount));
showAmount.textContent = web_common_1.amountToPretty(amount);
}
var url = URI(document.location.href);
@@ -44,7 +45,7 @@ System.register(["../lib/wallet/types", "../lib/web-common"], function(exports_1
throw Error("empty response");
}
if (!rawResp.error) {
- var resp = types_2.CreateReserveResponse.checked(rawResp);
+ var resp = wallet_1.CreateReserveResponse.checked(rawResp);
var q = {
mint: resp.mint,
reserve_pub: resp.reservePub,
@@ -67,12 +68,11 @@ System.register(["../lib/wallet/types", "../lib/web-common"], function(exports_1
exports_1("main", main);
return {
setters:[
- function (types_1_1) {
- types_1 = types_1_1;
- types_2 = types_1_1;
- },
function (web_common_1_1) {
web_common_1 = web_common_1_1;
+ },
+ function (wallet_1_1) {
+ wallet_1 = wallet_1_1;
}],
execute: function() {
"use strict";
diff --git a/extension/pages/confirm-create-reserve.tsx b/extension/pages/confirm-create-reserve.tsx
index e4d2d27e6..6a130eeff 100644
--- a/extension/pages/confirm-create-reserve.tsx
+++ b/extension/pages/confirm-create-reserve.tsx
@@ -14,9 +14,8 @@
TALER; see the file COPYING. If not, If not, see
*/
-import {AmountJson} from "../lib/wallet/types";
import {amountToPretty} from "../lib/web-common";
-import {CreateReserveResponse} from "../lib/wallet/types";
+import {AmountJson, CreateReserveResponse} from "../lib/wallet/wallet";
"use strict";
diff --git a/extension/popup/popup.tsx b/extension/popup/popup.tsx
index a9579f18c..ebd77dd2e 100644
--- a/extension/popup/popup.tsx
+++ b/extension/popup/popup.tsx
@@ -15,7 +15,7 @@
*/
-///
+///
///
"use strict";
diff --git a/extension/tsconfig.json b/extension/tsconfig.json
index 18539aa4e..5c2883da4 100644
--- a/extension/tsconfig.json
+++ b/extension/tsconfig.json
@@ -5,7 +5,9 @@
"experimentalDecorators": true,
"module": "system",
"sourceMap": true,
- "noLib": true
+ "noLib": true,
+ "noImplicitReturns": true,
+ "noFallthroughCasesInSwitch": true
},
"files": [
"lib/i18n.ts",
@@ -16,7 +18,6 @@
"lib/wallet/emscriptif.ts",
"lib/wallet/http.ts",
"lib/wallet/query.ts",
- "lib/wallet/types.ts",
"lib/wallet/wallet.ts",
"lib/wallet/wxmessaging.ts",
"background/main.ts",