2022-12-07 19:44:16 +01:00
|
|
|
import { canonicalizeBaseUrl } from "@gnu-taler/taler-util";
|
|
|
|
|
2022-12-07 13:29:36 +01:00
|
|
|
/**
|
|
|
|
* Validate (the number part of) an amount. If needed,
|
|
|
|
* replace comma with a dot. Returns 'false' whenever
|
|
|
|
* the input is invalid, the valid amount otherwise.
|
|
|
|
*/
|
2022-12-07 19:44:16 +01:00
|
|
|
export function validateAmount(maybeAmount: string | undefined): string | undefined {
|
2022-12-07 13:29:36 +01:00
|
|
|
const amountRegex = "^[0-9]+(.[0-9]+)?$";
|
|
|
|
if (!maybeAmount) {
|
|
|
|
console.log(`Entered amount (${maybeAmount}) mismatched <input> pattern.`);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (typeof maybeAmount !== "undefined" || maybeAmount !== "") {
|
|
|
|
console.log(`Maybe valid amount: ${maybeAmount}`);
|
|
|
|
// tolerating comma instead of point.
|
|
|
|
const re = RegExp(amountRegex);
|
|
|
|
if (!re.test(maybeAmount)) {
|
|
|
|
console.log(`Not using invalid amount '${maybeAmount}'.`);
|
2022-12-07 19:44:16 +01:00
|
|
|
return;
|
2022-12-07 13:29:36 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return maybeAmount;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extract IBAN from a Payto URI.
|
|
|
|
*/
|
|
|
|
export function getIbanFromPayto(url: string): string {
|
|
|
|
const pathSplit = new URL(url).pathname.split("/");
|
|
|
|
let lastIndex = pathSplit.length - 1;
|
|
|
|
// Happens if the path ends with "/".
|
|
|
|
if (pathSplit[lastIndex] === "") lastIndex--;
|
|
|
|
const iban = pathSplit[lastIndex];
|
|
|
|
return iban;
|
|
|
|
}
|
|
|
|
|
2022-12-07 19:44:16 +01:00
|
|
|
const maybeRootPath = "https://bank.demo.taler.net/demobanks/default/";
|
|
|
|
|
2022-12-07 13:29:36 +01:00
|
|
|
export function getBankBackendBaseUrl(): string {
|
|
|
|
const overrideUrl = localStorage.getItem("bank-base-url");
|
|
|
|
if (overrideUrl) {
|
|
|
|
console.log(
|
|
|
|
`using bank base URL ${overrideUrl} (override via bank-base-url localStorage)`,
|
|
|
|
);
|
2022-12-07 19:44:16 +01:00
|
|
|
} else {
|
|
|
|
console.log(`using bank base URL (${maybeRootPath})`);
|
2022-12-07 13:29:36 +01:00
|
|
|
}
|
2022-12-07 19:44:16 +01:00
|
|
|
return canonicalizeBaseUrl(overrideUrl ? overrideUrl : maybeRootPath)
|
|
|
|
|
2022-12-07 13:29:36 +01:00
|
|
|
}
|
2022-12-07 15:36:20 +01:00
|
|
|
|
|
|
|
export function undefinedIfEmpty<T extends object>(obj: T): T | undefined {
|
|
|
|
return Object.keys(obj).some((k) => (obj as any)[k] !== undefined)
|
|
|
|
? obj
|
|
|
|
: undefined;
|
|
|
|
}
|
2022-12-07 16:38:50 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Craft headers with Authorization and Content-Type.
|
|
|
|
*/
|
|
|
|
export function prepareHeaders(username?: string, password?: string): Headers {
|
|
|
|
const headers = new Headers();
|
|
|
|
if (username && password) {
|
|
|
|
headers.append(
|
|
|
|
"Authorization",
|
|
|
|
`Basic ${window.btoa(`${username}:${password}`)}`,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
headers.append("Content-Type", "application/json");
|
|
|
|
return headers;
|
|
|
|
}
|