summaryrefslogtreecommitdiff
path: root/packages/taler-wallet-cli/src/index.ts
diff options
context:
space:
mode:
authorFlorian Dold <florian@dold.me>2021-08-04 23:26:47 +0200
committerFlorian Dold <florian@dold.me>2021-08-04 23:26:47 +0200
commit0439096a534fa38f5522c3a1e152dc7b650545a6 (patch)
tree6472b2f602718d20b22d22ee6e69da000c9b1c59 /packages/taler-wallet-cli/src/index.ts
parent9769f6960173ba94d2e19dbb438c6bdf8764f1cd (diff)
downloadwallet-core-0439096a534fa38f5522c3a1e152dc7b650545a6.tar.gz
wallet-core-0439096a534fa38f5522c3a1e152dc7b650545a6.tar.bz2
wallet-core-0439096a534fa38f5522c3a1e152dc7b650545a6.zip
improved denomination generator
Diffstat (limited to 'packages/taler-wallet-cli/src/index.ts')
-rw-r--r--packages/taler-wallet-cli/src/index.ts22
1 files changed, 16 insertions, 6 deletions
diff --git a/packages/taler-wallet-cli/src/index.ts b/packages/taler-wallet-cli/src/index.ts
index 6bc4897fc..673bfab2a 100644
--- a/packages/taler-wallet-cli/src/index.ts
+++ b/packages/taler-wallet-cli/src/index.ts
@@ -40,6 +40,7 @@ import {
codecForString,
Logger,
Configuration,
+ getTimestampNow,
} from "@gnu-taler/taler-util";
import {
NodeHttpLib,
@@ -891,15 +892,24 @@ deploymentCli
.subcommand("coincfg", "gen-coin-config", {
help: "Generate a coin/denomination configuration for the exchange.",
})
- .requiredOption("currency", ["--currency"], clk.STRING, {
- help: "Currency to use",
+ .requiredOption("minAmount", ["--min-amount"], clk.STRING, {
+ help: "Smallest denomination",
+ })
+ .requiredOption("maxAmount", ["--max-amount"], clk.STRING, {
+ help: "Largest denomination",
})
.action(async (args) => {
let out = "";
- const currency = args.coincfg.currency;
- const min = Amounts.parseOrThrow(`${currency}:0.01`);
- const max = Amounts.parseOrThrow(`${currency}:100`);
+ const stamp = Math.floor((new Date()).getTime() / 1000);
+
+ const min = Amounts.parseOrThrow(args.coincfg.minAmount);
+ const max = Amounts.parseOrThrow(args.coincfg.maxAmount);
+ if (min.currency != max.currency) {
+ console.error("currency mismatch")
+ process.exit(1);
+ }
+ const currency = min.currency;
let x = min;
let n = 1;
@@ -908,7 +918,7 @@ deploymentCli
out += "\n";
while (Amounts.cmp(x, max) < 0) {
- out += `[COIN-${currency}_${n}]\n`;
+ out += `[COIN-${currency}-n${n}-t${stamp}]\n`;
out += `VALUE = ${Amounts.stringify(x)}\n`;
out += `DURATION_WITHDRAW = 7 days\n`;
out += `DURATION_SPEND = 2 years\n`;