diff options
author | Runxi Yu <me@runxiyu.org> | 2025-03-23 16:30:43 +0800 |
---|---|---|
committer | Runxi Yu <me@runxiyu.org> | 2025-03-23 16:30:43 +0800 |
commit | 97c8ed2c47c1d26ca55372b2f5943b4d54fd8079 (patch) | |
tree | bc4bea8602dbbcfac7f10e36ee88b2382c69c1b2 | |
parent | Remove extra newlines from tmpl and csolver (diff) | |
download | powxy-97c8ed2c47c1d26ca55372b2f5943b4d54fd8079.tar.gz powxy-97c8ed2c47c1d26ca55372b2f5943b4d54fd8079.tar.zst powxy-97c8ed2c47c1d26ca55372b2f5943b4d54fd8079.zip |
Reindent the HTML
-rw-r--r-- | tmpl.go | 186 |
1 files changed, 93 insertions, 93 deletions
@@ -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>`) |