summaryrefslogtreecommitdiffstats
path: root/browser/base/content/newInstallPage.js
blob: 2b378a30d4713dcfa5d1ffdbe5453f593799e8e5 (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
/* 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/. */

/* global RPMGetUpdateChannel, RPMGetFxAccountsEndpoint */

const PARAMS = new URL(location).searchParams;
const ENTRYPOINT = "new-install-page";
const SOURCE = `new-install-page-${RPMGetUpdateChannel()}`;
const CAMPAIGN = "dedicated-profiles";
const ENDPOINT = PARAMS.get("endpoint");

function appendAccountsParams(url) {
  url.searchParams.set("entrypoint", ENTRYPOINT);
  url.searchParams.set("utm_source", SOURCE);
  url.searchParams.set("utm_campaign", CAMPAIGN);
}

function appendParams(url, params) {
  appendAccountsParams(url);

  for (let [key, value] of Object.entries(params)) {
    url.searchParams.set(key, value);
  }
}

async function requestFlowMetrics() {
  let requestURL = new URL(await endpoint);
  requestURL.pathname = "metrics-flow";
  appendParams(requestURL, {
    form_type: "email",
  });

  let response = await fetch(requestURL, { credentials: "omit" });
  if (response.status === 200) {
    return response.json();
  }

  throw new Error(`Failed to retrieve metrics: ${response.status}`);
}

async function submitForm(event) {
  // We never want to submit the form.
  event.preventDefault();

  let input = document.getElementById("sync-input");

  let { flowId, flowBeginTime } = await metrics;

  let requestURL = new URL(await endpoint);
  appendParams(requestURL, {
    action: "email",
    utm_campaign: CAMPAIGN,
    email: input.value,
    flow_id: flowId,
    flow_begin_time: flowBeginTime,
  });

  window.open(requestURL, "_blank", "noopener");
  document.getElementById("sync").hidden = true;
}

const endpoint = RPMGetFxAccountsEndpoint(ENTRYPOINT);

// This must come before the CSP is set or it will be blocked.
const metrics = requestFlowMetrics();

document.addEventListener(
  "DOMContentLoaded",
  () => {
    document.getElementById("sync").addEventListener("submit", submitForm);
  },
  { once: true }
);