File: referrer.sjs

package info (click to toggle)
firefox-esr 128.13.0esr-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 4,230,012 kB
  • sloc: cpp: 7,103,971; javascript: 6,088,450; ansic: 3,653,980; python: 1,212,330; xml: 594,604; asm: 420,652; java: 182,969; sh: 71,124; makefile: 20,747; perl: 13,449; objc: 12,399; yacc: 4,583; cs: 3,846; pascal: 2,973; lex: 1,720; ruby: 1,194; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10
file content (49 lines) | stat: -rw-r--r-- 1,323 bytes parent folder | download | duplicates (15)
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
// A 1x1 PNG image.
// Source: https://commons.wikimedia.org/wiki/File:1x1.png (Public Domain)
const IMAGE = atob(
  "iVBORw0KGgoAAAANSUhEUgAAAAEAAAABAQMAAAAl21bKAAAAA1BMVEUAA" +
    "ACnej3aAAAAAXRSTlMAQObYZgAAAApJREFUCNdjYAAAAAIAAeIhvDMAAAAASUVORK5CYII="
);

const IFRAME =
  "<!DOCTYPE html>\n" +
  "<script>\n" +
  "onmessage = event => {\n" +
  "parent.postMessage(document.referrer, '*');\n" +
  "};\n" +
  "</script>";

function handleRequest(aRequest, aResponse) {
  aResponse.setStatusLine(aRequest.httpVersion, 200);

  let key;
  if (aRequest.queryString.includes("what=script")) {
    key = "script";
  } else if (aRequest.queryString.includes("what=image")) {
    key = "image";
  } else {
    key = "iframe";
  }

  if (aRequest.queryString.includes("result")) {
    aResponse.write(getState(key));
    setState(key, "");
    return;
  }

  if (aRequest.hasHeader("Referer")) {
    let referrer = aRequest.getHeader("Referer");
    setState(key, referrer);
  }

  if (key == "script") {
    aResponse.setHeader("Content-Type", "text/javascript", false);
    aResponse.write("42;");
  } else if (key == "image") {
    aResponse.setHeader("Content-Type", "image/png", false);
    aResponse.write(IMAGE);
  } else {
    aResponse.setHeader("Content-Type", "text/html", false);
    aResponse.write(IFRAME);
  }
}