summaryrefslogtreecommitdiffstats
path: root/dom/workers/test/referrer_test_server.sjs
blob: 44ec10c456fd5624a3e72a049df2d8b46fb6731e (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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
Components.utils.importGlobalProperties(["URLSearchParams"]);
const SJS = "referrer_test_server.sjs?";
const SHARED_KEY = SJS;

var SAME_ORIGIN = "https://example.com/tests/dom/workers/test/" + SJS;
var CROSS_ORIGIN = "https://test2.example.com/tests/dom/workers/test/" + SJS;
var DOWNGRADE = "http://example.com/tests/dom/workers/test/" + SJS;

function createUrl(aRequestType, aPolicy) {
  var searchParams = new URLSearchParams();
  searchParams.append("ACTION", "request-worker");
  searchParams.append("Referrer-Policy", aPolicy);
  searchParams.append("TYPE", aRequestType);

  var url = SAME_ORIGIN;

  if (aRequestType === "cross-origin") {
    url = CROSS_ORIGIN;
  } else if (aRequestType === "downgrade") {
    url = DOWNGRADE;
  }

  return url + searchParams.toString();
}
function createWorker(aRequestType, aPolicy) {
  return `
    onmessage = function() {
      fetch("${createUrl(aRequestType, aPolicy)}").then(function () {
        postMessage(42);
        close();
      });
    }
  `;
}

function handleRequest(request, response) {
  var params = new URLSearchParams(request.queryString);
  var policy = params.get("Referrer-Policy");
  var type = params.get("TYPE");
  var action = params.get("ACTION");
  response.setHeader("Content-Security-Policy", "default-src *", false);
  response.setHeader("Access-Control-Allow-Origin", "*", false);

  if (policy) {
    response.setHeader("Referrer-Policy", policy, false);
  }

  if (action === "test") {
    response.setHeader("Content-Type", "text/javascript", false);
    response.write(createWorker(type, policy));
    return;
  }

  if (action === "resetState") {
    setSharedState(SHARED_KEY, "{}");
    response.write("");
    return;
  }

  if (action === "get-test-results") {
    response.setHeader("Cache-Control", "no-cache", false);
    response.setHeader("Content-Type", "text/plain", false);
    response.write(getSharedState(SHARED_KEY));
    return;
  }

  if (action === "request-worker") {
    var result = getSharedState(SHARED_KEY);
    result = result ? JSON.parse(result) : {};
    var referrerLevel = "none";
    var test = {};

    if (request.hasHeader("Referer")) {
      var referrer = request.getHeader("Referer");
      if (referrer.indexOf("referrer_test_server") > 0) {
        referrerLevel = "full";
      } else if (referrer.indexOf("https://example.com") == 0) {
        referrerLevel = "origin";
      } else {
        // this is never supposed to happen
        referrerLevel = "other-origin";
      }
      test.referrer = referrer;
    } else {
      test.referrer = "";
    }

    test.policy = referrerLevel;
    test.expected = policy;

    // test id equals type + "-" + policy
    // Ex: same-origin-default
    result[type + "-" + policy] = test;
    setSharedState(SHARED_KEY, JSON.stringify(result));

    response.write("'hello world'");
    return;
  }
}