aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRunxi Yu <me@runxiyu.org>2025-03-23 16:30:43 +0800
committerRunxi Yu <me@runxiyu.org>2025-03-23 16:30:43 +0800
commit97c8ed2c47c1d26ca55372b2f5943b4d54fd8079 (patch)
treebc4bea8602dbbcfac7f10e36ee88b2382c69c1b2
parentRemove extra newlines from tmpl and csolver (diff)
downloadpowxy-97c8ed2c47c1d26ca55372b2f5943b4d54fd8079.tar.gz
powxy-97c8ed2c47c1d26ca55372b2f5943b4d54fd8079.tar.zst
powxy-97c8ed2c47c1d26ca55372b2f5943b4d54fd8079.zip
Reindent the HTML
-rw-r--r--tmpl.go186
1 files changed, 93 insertions, 93 deletions
diff --git a/tmpl.go b/tmpl.go
index 64cceea..de12cc6 100644
--- a/tmpl.go
+++ b/tmpl.go
@@ -139,30 +139,30 @@ func init() {
}
</style>
<script>
-/*
-@licstart The following is the entire license notice for the
-JavaScript code in this page.
-
-Copyright (C) 2025 Runxi Yu
-
-The JavaScript code in this page is free software: you can
-redistribute it and/or modify it under the terms of the GNU
-General Public License (GNU GPL) as published by the Free Software
-Foundation, either version 3 of the License, or (at your option)
-any later version. The code is distributed WITHOUT ANY WARRANTY;
-without even the implied warranty of MERCHANTABILITY or FITNESS
-FOR A PARTICULAR PURPOSE. See the GNU GPL for more details.
-
-As additional permission under GNU GPL version 3 section 7, you
-may distribute non-source (e.g., minimized or compacted) forms of
-that code without the copy of the GNU GPL normally required by
-section 4, provided you include this license notice and a URL
-through which recipients can access the Corresponding Source.
-
-@licend The above is the entire license notice
-for the JavaScript code in this page.
-*/
-</script>
+ /*
+ @licstart The following is the entire license notice for the
+ JavaScript code in this page.
+
+ Copyright (C) 2025 Runxi Yu
+
+ The JavaScript code in this page is free software: you can
+ redistribute it and/or modify it under the terms of the GNU
+ General Public License (GNU GPL) as published by the Free Software
+ Foundation, either version 3 of the License, or (at your option)
+ any later version. The code is distributed WITHOUT ANY WARRANTY;
+ without even the implied warranty of MERCHANTABILITY or FITNESS
+ FOR A PARTICULAR PURPOSE. See the GNU GPL for more details.
+
+ As additional permission under GNU GPL version 3 section 7, you
+ may distribute non-source (e.g., minimized or compacted) forms of
+ that code without the copy of the GNU GPL normally required by
+ section 4, provided you include this license notice and a URL
+ through which recipients can access the Corresponding Source.
+
+ @licend The above is the entire license notice
+ for the JavaScript code in this page.
+ */
+ </script>
</head>
<body>
<main>
@@ -214,80 +214,80 @@ for the JavaScript code in this page.
</main>
<script>
- document.addEventListener("DOMContentLoaded", function() {
- let challenge_b64 = "{{ .UnsignedTokenBase64 }}";
- let difficulty = {{ .Global.NeedBits }};
- let form = document.querySelector("form");
- let field = form.querySelector("input[name='powxy']");
- let status_el = document.getElementById("solver_status");
-
- if (!window.crypto || !window.crypto.subtle) {
- status_el.textContent = "SubtleCrypto not available. You must solve the challenge externally.";
- return;
- }
- status_el.textContent = "SubtleCrypto detected. Attempting to solve the challenge automatically...";
-
- let solver_active = true;
- form.addEventListener("submit", function() {
- solver_active = false;
- });
-
- async function solve_pow() {
- let token_bytes = Uint8Array.from(
- atob(challenge_b64),
- ch => ch.charCodeAt(0)
- );
-
- let nonce = 0n;
- let buf = new ArrayBuffer(8);
- let view = new DataView(buf);
-
- while (solver_active) {
- view.setBigUint64(0, nonce, true);
-
- let candidate = new Uint8Array(token_bytes.length + 8);
- candidate.set(token_bytes, 0);
- candidate.set(new Uint8Array(buf), token_bytes.length);
-
- let digest_buffer = await crypto.subtle.digest("SHA-256", candidate);
- let digest = new Uint8Array(digest_buffer);
-
- if (has_leading_zero_bits(digest, difficulty)) {
- let nonce_str = String.fromCharCode(...new Uint8Array(buf));
- field.value = btoa(nonce_str);
-
- status_el.textContent = "A solution has been found automatically in " + nonce + " iterations.";
- return;
- }
-
- nonce++;
-
- if ((nonce & 0x00FFn) === 0n) {
- status_el.textContent = "Attempting to solve automatically. Tried " + nonce + " candidates so far...";
- await new Promise(r => setTimeout(r, 0));
- }
+ document.addEventListener("DOMContentLoaded", function() {
+ let challenge_b64 = "{{ .UnsignedTokenBase64 }}";
+ let difficulty = {{ .Global.NeedBits }};
+ let form = document.querySelector("form");
+ let field = form.querySelector("input[name='powxy']");
+ let status_el = document.getElementById("solver_status");
+
+ if (!window.crypto || !window.crypto.subtle) {
+ status_el.textContent = "SubtleCrypto not available. You must solve the challenge externally.";
+ return;
}
- }
-
- function has_leading_zero_bits(digest, bits) {
- let full_bytes = bits >>> 3;
- for (let i = 0; i < full_bytes; i++) {
- if (digest[i] !== 0) {
- return false;
+ status_el.textContent = "SubtleCrypto detected. Attempting to solve the challenge automatically...";
+
+ let solver_active = true;
+ form.addEventListener("submit", function() {
+ solver_active = false;
+ });
+
+ async function solve_pow() {
+ let token_bytes = Uint8Array.from(
+ atob(challenge_b64),
+ ch => ch.charCodeAt(0)
+ );
+
+ let nonce = 0n;
+ let buf = new ArrayBuffer(8);
+ let view = new DataView(buf);
+
+ while (solver_active) {
+ view.setBigUint64(0, nonce, true);
+
+ let candidate = new Uint8Array(token_bytes.length + 8);
+ candidate.set(token_bytes, 0);
+ candidate.set(new Uint8Array(buf), token_bytes.length);
+
+ let digest_buffer = await crypto.subtle.digest("SHA-256", candidate);
+ let digest = new Uint8Array(digest_buffer);
+
+ if (has_leading_zero_bits(digest, difficulty)) {
+ let nonce_str = String.fromCharCode(...new Uint8Array(buf));
+ field.value = btoa(nonce_str);
+
+ status_el.textContent = "A solution has been found automatically in " + nonce + " iterations.";
+ return;
+ }
+
+ nonce++;
+
+ if ((nonce & 0x00FFn) === 0n) {
+ status_el.textContent = "Attempting to solve automatically. Tried " + nonce + " candidates so far...";
+ await new Promise(r => setTimeout(r, 0));
+ }
}
}
- let remainder = bits & 7;
- if (remainder !== 0) {
- let mask = 0xFF << (8 - remainder);
- if ((digest[full_bytes] & mask) !== 0) {
- return false;
+
+ function has_leading_zero_bits(digest, bits) {
+ let full_bytes = bits >>> 3;
+ for (let i = 0; i < full_bytes; i++) {
+ if (digest[i] !== 0) {
+ return false;
+ }
+ }
+ let remainder = bits & 7;
+ if (remainder !== 0) {
+ let mask = 0xFF << (8 - remainder);
+ if ((digest[full_bytes] & mask) !== 0) {
+ return false;
+ }
}
+ return true;
}
- return true;
- }
-
- solve_pow();
- });
+
+ solve_pow();
+ });
</script>
</body>
</html>`)