summaryrefslogtreecommitdiffstats
path: root/toolkit/components/url-classifier/tests/mochitest/trackerFrame.sjs
blob: be31e666b051014773d2be25bdc2537915f20375 (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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

const stateTotalRequests = "total-request";
const stateCallback = "callback-response";
const stateTrackersWithCookie = "trackers-with-cookie";
const stateTrackersWithoutCookie = "trackers-without-cookie";
const stateReceivedTrackers = "received-trackers";
const stateResponseType = "response-tracker-with-cookie";

function reset() {
  setState(stateCallback, "");
  setState(stateTrackersWithCookie, "");
  setState(stateTrackersWithoutCookie, "");
  setState(stateReceivedTrackers, "");
  setState(stateResponseType, "");
}

function handleRequest(aRequest, aResponse) {
  let params = new URLSearchParams(aRequest.queryString);

  // init the server and tell the server the total number requests to process
  // server set the cookie
  if (params.has("init")) {
    setState(stateTotalRequests, params.get("init"));

    aResponse.setStatusLine(aRequest.httpVersion, 200);
    aResponse.setHeader("Content-Type", "text/plain", false);

    // Prepare the cookie
    aResponse.setHeader("Set-Cookie", "cookie=1234; SameSite=None; Secure");
    aResponse.setHeader(
      "Access-Control-Allow-Origin",
      aRequest.getHeader("Origin"),
      false
    );
    aResponse.setHeader("Access-Control-Allow-Credentials", "true", false);
    aResponse.write("begin-test");
    // register the callback response, the response will be fired after receiving
    // all the request
  } else if (params.has("callback")) {
    aResponse.processAsync();
    aResponse.setHeader("Content-Type", "text/plain", false);
    aResponse.setHeader(
      "Access-Control-Allow-Origin",
      aRequest.getHeader("Origin"),
      false
    );
    aResponse.setHeader("Access-Control-Allow-Credentials", "true", false);

    setState(stateResponseType, params.get("callback"));
    setObjectState(stateCallback, aResponse);
  } else {
    let count = parseInt(getState(stateReceivedTrackers) || 0) + 1;
    setState(stateReceivedTrackers, count.toString());

    let state = "";
    if (aRequest.hasHeader("Cookie")) {
      state = stateTrackersWithCookie;
    } else {
      state = stateTrackersWithoutCookie;
    }

    let ids = params.get("id").concat(",", getState(state));
    setState(state, ids);

    if (getState(stateTotalRequests) == getState(stateReceivedTrackers)) {
      getObjectState(stateCallback, r => {
        if (getState(stateResponseType) == "with-cookie") {
          r.write(getState(stateTrackersWithCookie));
        } else {
          r.write(getState(stateTrackersWithoutCookie));
        }
        r.finish();
        reset();
      });
    }
  }
}