aboutsummaryrefslogtreecommitdiff
path: root/web/js/main.mjs
blob: 297f16f5249b352ef9b0617866d976350630014c (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
import processFast from "./proof-of-work.mjs";
import processSlow from "./proof-of-work-slow.mjs";
import { testVideo } from "./video.mjs";

const algorithms = {
  "fast": processFast,
  "slow": processSlow,
}

// from Xeact
const u = (url = "", params = {}) => {
  let result = new URL(url, window.location.href);
  Object.entries(params).forEach((kv) => {
    let [k, v] = kv;
    result.searchParams.set(k, v);
  });
  return result.toString();
};

const imageURL = (mood, cacheBuster) =>
  u(`/.within.website/x/cmd/anubis/static/img/${mood}.webp`, { cacheBuster });

(async () => {
  const status = document.getElementById('status');
  const image = document.getElementById('image');
  const title = document.getElementById('title');
  const spinner = document.getElementById('spinner');
  const anubisVersion = JSON.parse(document.getElementById('anubis_version').textContent);

  // const testarea = document.getElementById('testarea');

  // const videoWorks = await testVideo(testarea);
  // console.log(`videoWorks: ${videoWorks}`);

  // if (!videoWorks) {
  //   title.innerHTML = "Oh no!";
  //   status.innerHTML = "Checks failed. Please check your browser's settings and try again.";
  //   image.src = imageURL("sad");
  //   spinner.innerHTML = "";
  //   spinner.style.display = "none";
  //   return;
  // }

  status.innerHTML = 'Calculating...';

  const { challenge, rules } = await fetch("/.within.website/x/cmd/anubis/api/make-challenge", { method: "POST" })
    .then(r => {
      if (!r.ok) {
        throw new Error("Failed to fetch config");
      }
      return r.json();
    })
    .catch(err => {
      title.innerHTML = "Oh no!";
      status.innerHTML = `Failed to fetch config: ${err.message}`;
      image.src = imageURL("sad", anubisVersion);
      spinner.innerHTML = "";
      spinner.style.display = "none";
      throw err;
    });

  const process = algorithms[rules.algorithm];
  if (!process) {
    title.innerHTML = "Oh no!";
    status.innerHTML = `Failed to resolve check algorithm. You may want to reload the page.`;
    image.src = imageURL("sad", anubisVersion);
    spinner.innerHTML = "";
    spinner.style.display = "none";
    return;
  }

  status.innerHTML = `Calculating...<br/>Difficulty: ${rules.report_as}`;

  const t0 = Date.now();
  const { hash, nonce } = await process(challenge, rules.difficulty);
  const t1 = Date.now();
  console.log({ hash, nonce });

  title.innerHTML = "Success!";
  status.innerHTML = `Done! Took ${t1 - t0}ms, ${nonce} iterations`;
  image.src = imageURL("happy", anubisVersion);
  spinner.innerHTML = "";
  spinner.style.display = "none";

  setTimeout(() => {
    const redir = window.location.href;
    window.location.href = u("/.within.website/x/cmd/anubis/api/pass-challenge", { response: hash, nonce, redir, elapsedTime: t1 - t0 });
  }, 250);
})();