blob: bbdb75636443f28882f963b00a4d790a5fc47cca (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
const HTTP_ORIGIN = "http://example.com";
const HTTPS_ORIGIN = "https://example.com";
const URI_PATH =
"/browser/browser/components/contextualidentity/test/browser/saveLink.sjs";
Cu.importGlobalProperties(["URLSearchParams"]);
function handleRequest(aRequest, aResponse) {
var params = new URLSearchParams(aRequest.queryString);
// This is the first request, where we set the cookie.
if (params.has("UCI")) {
aResponse.setStatusLine(aRequest.httpVersion, 200);
aResponse.setHeader("Set-Cookie", "UCI=" + params.get("UCI"));
aResponse.write(
"<html><body><a href='" +
HTTPS_ORIGIN +
URI_PATH +
"?redirect=1' id='fff'>this is a link</a></body></html>"
);
return;
}
// Second request. This is the save-as content, but we make a redirect to see
// if we are able to follow it.
if (params.has("redirect")) {
aResponse.setStatusLine(aRequest.httpVersion, 302, "Found");
aResponse.setHeader(
"Location",
HTTP_ORIGIN + URI_PATH + "?download=1",
false
);
aResponse.write("Redirect!");
return;
}
// This is the 3rd request where we offer the content to be saved.
if (params.has("download")) {
setState("downloadUCI", aRequest.getHeader("Cookie"));
aResponse.setStatusLine(aRequest.httpVersion, 200);
aResponse.write("All Good!");
return;
}
// This is the last request to check that the download happened with the correct cookie
if (params.has("result")) {
aResponse.setStatusLine(aRequest.httpVersion, 200);
aResponse.write("Result:" + getState("downloadUCI"));
return;
}
// We should not be here!
aResponse.setStatusLine(aRequest.httpVersion, 500);
aResponse.write("ERROR!!!");
}
|