File: cookieServer.sjs

package info (click to toggle)
firefox 141.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,550,588 kB
  • sloc: cpp: 7,426,506; javascript: 6,367,238; ansic: 3,707,351; python: 1,369,002; xml: 623,983; asm: 426,918; java: 184,324; sh: 64,488; makefile: 19,203; objc: 13,059; perl: 12,955; yacc: 4,583; cs: 3,846; pascal: 3,352; lex: 1,720; ruby: 1,071; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10
file content (36 lines) | stat: -rw-r--r-- 1,144 bytes parent folder | download | duplicates (4)
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
/* Any copyright is dedicated to the Public Domain.
 * http://creativecommons.org/publicdomain/zero/1.0/
 */

// A 1x1 PNG image.
// Source: https://commons.wikimedia.org/wiki/File:1x1.png (Public Domain)
const IMAGE = atob(
  "iVBORw0KGgoAAAANSUhEUgAAAAEAAAABAQMAAAAl21bKAAAAA1BMVEUAA" +
    "ACnej3aAAAAAXRSTlMAQObYZgAAAApJREFUCNdjYAAAAAIAAeIhvDMAAAAASUVORK5CYII="
);

function handleRequest(request, response) {
  response.setStatusLine(request.httpVersion, 200);
  if (
    request.queryString &&
    request.queryString.includes("type=image-no-cookie")
  ) {
    response.setHeader("Content-Type", "image/png", false);
    response.write(IMAGE);
  } else if (
    request.queryString &&
    request.queryString.includes("type=partitioned")
  ) {
    response.setHeader("Access-Control-Allow-Origin", "https://example.net");
    response.setHeader("Access-Control-Allow-Credentials", "true");
    response.setHeader(
      "Set-Cookie",
      "foopy=1; SameSite=None; Secure; Partitioned"
    );

    dump(" ==== TIM: cookie served\n");
  } else {
    response.setHeader("Set-Cookie", "foopy=1");
    response.write("cookie served");
  }
}