taler URI parsing
* add support for non-https taler://pay URIs * implement path prefix properly
This commit is contained in:
parent
e3a5dbfe32
commit
3f6d3d186b
@ -86,7 +86,7 @@ test("taler pay url parsing: instance", (t) => {
|
|||||||
t.fail();
|
t.fail();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
t.is(r1.downloadUrl, "https://example.com/instances/myinst/public/proposal?order_id=myorder");
|
t.is(r1.downloadUrl, "https://example.com/public/instances/myinst/proposal?order_id=myorder");
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
@ -97,7 +97,47 @@ test("taler pay url parsing: path prefix and instance", (t) => {
|
|||||||
t.fail();
|
t.fail();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
t.is(r1.downloadUrl, "https://example.com/mypfx/instances/myinst/public/proposal?order_id=myorder");
|
t.is(r1.downloadUrl, "https://example.com/mypfx/instances/myinst/proposal?order_id=myorder");
|
||||||
|
});
|
||||||
|
|
||||||
|
test("taler pay url parsing: complex path prefix", (t) => {
|
||||||
|
const url1 = "taler://pay/example.com/mypfx%2Fpublic/-/myorder";
|
||||||
|
const r1 = parsePayUri(url1);
|
||||||
|
if (!r1) {
|
||||||
|
t.fail();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
t.is(r1.downloadUrl, "https://example.com/mypfx/public/proposal?order_id=myorder");
|
||||||
|
});
|
||||||
|
|
||||||
|
test("taler pay url parsing: complex path prefix and instance", (t) => {
|
||||||
|
const url1 = "taler://pay/example.com/mypfx%2Fpublic/foo/myorder";
|
||||||
|
const r1 = parsePayUri(url1);
|
||||||
|
if (!r1) {
|
||||||
|
t.fail();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
t.is(r1.downloadUrl, "https://example.com/mypfx/public/instances/foo/proposal?order_id=myorder");
|
||||||
|
});
|
||||||
|
|
||||||
|
test("taler pay url parsing: non-https #1", (t) => {
|
||||||
|
const url1 = "taler://pay/example.com/-/-/myorder?insecure=1";
|
||||||
|
const r1 = parsePayUri(url1);
|
||||||
|
if (!r1) {
|
||||||
|
t.fail();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
t.is(r1.downloadUrl, "http://example.com/public/proposal?order_id=myorder");
|
||||||
|
});
|
||||||
|
|
||||||
|
test("taler pay url parsing: non-https #2", (t) => {
|
||||||
|
const url1 = "taler://pay/example.com/-/-/myorder?insecure=2";
|
||||||
|
const r1 = parsePayUri(url1);
|
||||||
|
if (!r1) {
|
||||||
|
t.fail();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
t.is(r1.downloadUrl, "https://example.com/public/proposal?order_id=myorder");
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
@ -61,6 +61,7 @@ export function parseWithdrawUri(s: string): WithdrawUriResult | undefined {
|
|||||||
|
|
||||||
export function parsePayUri(s: string): PayUriResult | undefined {
|
export function parsePayUri(s: string): PayUriResult | undefined {
|
||||||
const parsedUri = new URI(s);
|
const parsedUri = new URI(s);
|
||||||
|
const query: any = parsedUri.query(true);
|
||||||
if (parsedUri.scheme() === "http" || parsedUri.scheme() === "https") {
|
if (parsedUri.scheme() === "http" || parsedUri.scheme() === "https") {
|
||||||
return {
|
return {
|
||||||
downloadUrl: s,
|
downloadUrl: s,
|
||||||
@ -96,7 +97,7 @@ export function parsePayUri(s: string): PayUriResult | undefined {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (maybePath === "-") {
|
if (maybePath === "-") {
|
||||||
maybePath = "";
|
maybePath = "public/";
|
||||||
} else {
|
} else {
|
||||||
maybePath = decodeURIComponent(maybePath) + "/";
|
maybePath = decodeURIComponent(maybePath) + "/";
|
||||||
}
|
}
|
||||||
@ -105,8 +106,13 @@ export function parsePayUri(s: string): PayUriResult | undefined {
|
|||||||
maybeInstancePath = `instances/${maybeInstance}/`;
|
maybeInstancePath = `instances/${maybeInstance}/`;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let protocol = "https";
|
||||||
|
if (query["insecure"] === "1") {
|
||||||
|
protocol = "http";
|
||||||
|
}
|
||||||
|
|
||||||
const downloadUrl = new URI(
|
const downloadUrl = new URI(
|
||||||
"https://" + host + "/" + decodeURIComponent(maybePath) + maybeInstancePath + "public/proposal",
|
protocol + "://" + host + "/" + decodeURIComponent(maybePath) + maybeInstancePath + "proposal",
|
||||||
)
|
)
|
||||||
.addQuery({ order_id: orderId })
|
.addQuery({ order_id: orderId })
|
||||||
.href();
|
.href();
|
||||||
|
Loading…
Reference in New Issue
Block a user