You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

202 lines
8.6 KiB

<!doctype html>
<html lang="en-US" class="h-100">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>ETHdos fold</title>
<!-- Bootstrap CSS -->
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet">
<style>
body {
background-color: #1a1a1a;
color: #d4d4d4;
}
.btn-primary {
background-color: #6f42c1;
border-color: #6f42c1;
}
.btn-primary:hover, .btn-primary:focus {
background-color: #5a32a3;
border-color: #5a32a3;
}
.btn-primary:active {
background-color: #4a2785 !important;
border-color: #4a2785 !important;
}
#console-out {
font-family: monospace;
font-size:75%;
padding: 10px;
background-color: #2d2d2d;
color: #d4d4d4;
border-radius: 5px;
overflow: scroll;
height: 70vh;
}
#console-out p { margin:0px;}
#console-out .log { color: #d4d4d4; }
#console-out .warn { color: #ffa500; }
#console-out .error { color: #ff6b6b; }
#console-out .info { color: #4fc3f7; }
textarea {
background-color: #2d2d2d;
color: #d4d4d4;
border: 1px solid #444;
margin-top:5px;
}
.box {
padding-top: 10px;
border: 1px solid #2d2d2d;
border-radius: 5px;
}
a {
color: #6f42c1;
}
</style>
</head>
<body class="container">
<a target="_blank" href="https://github.com/arnaucube/ethdos-fold" class="github-corner" aria-label="View source on GitHub"><svg width="80" height="80" viewBox="0 0 250 250" style="fill:#fff; color:#151513; position: absolute; top: 0; border: 0; right: 0;" aria-hidden="true"><path d="M0,0 L115,115 L130,115 L142,142 L250,250 L250,0 Z"></path><path d="M128.3,109.0 C113.8,99.7 119.0,89.6 119.0,89.6 C122.0,82.7 120.5,78.6 120.5,78.6 C119.2,72.0 123.4,76.3 123.4,76.3 C127.3,80.9 125.5,87.3 125.5,87.3 C122.9,97.6 130.6,101.9 134.4,103.2" fill="currentColor" style="transform-origin: 130px 106px;" class="octo-arm"></path><path d="M115.0,115.0 C114.9,115.1 118.7,116.5 119.8,115.4 L133.7,101.6 C136.9,99.2 139.9,98.4 142.2,98.6 C133.8,88.0 127.5,74.4 143.8,58.0 C148.5,53.4 154.0,51.2 159.7,51.0 C160.3,49.4 163.2,43.6 171.4,40.1 C171.4,40.1 176.1,42.5 178.8,56.2 C183.1,58.6 187.2,61.8 190.9,65.4 C194.5,69.0 197.7,73.2 200.1,77.6 C213.8,80.2 216.3,84.9 216.3,84.9 C212.7,93.1 206.9,96.0 205.4,96.6 C205.1,102.4 203.0,107.8 198.3,112.5 C181.9,128.9 168.3,122.5 157.7,114.1 C157.9,116.9 156.7,120.9 152.7,124.9 L141.0,136.5 C139.8,137.7 141.6,141.9 141.8,141.8 Z" fill="currentColor" class="octo-body"></path></svg></a><style>.github-corner:hover .octo-arm{animation:octocat-wave 560ms ease-in-out}@keyframes octocat-wave{0%,100%{transform:rotate(0)}20%,60%{transform:rotate(-25deg)}40%,80%{transform:rotate(10deg)}}@media (max-width:500px){.github-corner:hover .octo-arm{animation:none}.github-corner .octo-arm{animation:octocat-wave 560ms ease-in-out}}</style>
<div class="container py-5">
<div class="row">
<div class="col-md-1">
</div>
<div class="col-md-6 box">
<h2 class="text-center mb-4">ETHdos fold</h2>
<p>Follows the ideas of ETHdos (<a target="_blank" href="https://ethdos.xyz/blog">https://ethdos.xyz/blog</a>), but using Folding Schemes.</p>
<p style="font-size:90%;">It uses <a target="_blank" href="https://github.com/privacy-scaling-explorations/sonobe">Sonobe</a> under the hood, compiled to WASM.</a>
<p style="font-style:italic;font-size:80%;">
Current version does not parallelize in wasm. Same execution can be run natively (no wasm), instructions <a target="_blank" href="https://github.com/arnaucube/ethdos-fold">in the repo</a>.<br>
In the same laptop, natively takes ~290ms per step, in-browser takes ~1700ms per step.
</p>
<button id="btn_gen_params" class="btn btn-primary">1. gen_params</button>
<div class="mb-3">
<!-- <label for="params" class="form-label">params:</label> -->
<textarea id="params" class="form-control" rows="3">params</textarea>
</div>
<div class="mb-3">
<button id="btn_gen_sigs" class="btn btn-primary">2. gen_sigs</button><br>
<!-- <label for="sigs" class="form-label">sigs and pks:</label> -->
<textarea id="sigs" class="form-control" rows="3">sigs and pks</textarea>
</div>
<div class="mb-3">
<button id="btn_fold_sigs" class="btn btn-primary">3. fold_sigs</button><br>
<!-- <label for="ivc_proof" class="form-label">ivc proof:</label> -->
<textarea id="ivc_proof" class="form-control" rows="3">ivc proof</textarea>
</div>
<button id="btn_verify_proof" class="btn btn-primary">4. verify_proof</button>
</div>
<div class="col-md-4">
logs:
<span id="spinner"></span>
<p style="font-style:italic;">(Open the browser console to see the execution logs)</p>
<div id="console-out" class="mt-4">
(logs will appear after the execution of each button ends)
</div>
</div>
</div>
</div>
<!-- Bootstrap JS -->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js"></script>
<script type="module">
import init, { gen_params, gen_sigs, fold_sigs, verify_proof } from "./pkg/ethdos_fold.js";
const n_sigs = 5;
await init();
console.log("ready");
document.getElementById('btn_gen_params').addEventListener('click', () => {
spinner_on();
setTimeout(() => {
let params = gen_params();
document.getElementById("params").innerHTML = JSON.stringify(params);
console.info("folding scheme params generated");
spinner_off();
}, 500);
});
document.getElementById('btn_gen_sigs').addEventListener('click', () => {
spinner_on();
let sigs = gen_sigs(n_sigs);
setTimeout(() => {
document.getElementById("sigs").innerHTML = JSON.stringify(sigs);
spinner_off();
console.info(`${n_sigs} signatures generated`);
}, 500);
});
document.getElementById('btn_fold_sigs').addEventListener('click', () => {
spinner_on();
setTimeout(() => {
let params = JSON.parse(document.getElementById("params").innerHTML);
let sigs = JSON.parse(document.getElementById("sigs").innerHTML);
let ivc_proof = fold_sigs(params, sigs);
document.getElementById("ivc_proof").innerHTML = JSON.stringify(ivc_proof);
console.info(`ivc_proof generated, proving distance of ${n_sigs} degrees (${n_sigs} recursive proofs) from the initial public key`);
spinner_off();
}, 500);
});
document.getElementById('btn_verify_proof').addEventListener('click', () => {
spinner_on();
setTimeout(() => {
let params = JSON.parse(document.getElementById("params").innerHTML);
let ivc_proof = JSON.parse(document.getElementById("ivc_proof").innerHTML);
let v = verify_proof(params[0], ivc_proof);
console.info("verification result:");
console.info(v);
spinner_off();
}, 500);
});
var oldLog = console.log;
var oldWarn = console.warn;
var oldError = console.error;
var oldInfo = console.info;
var outputDiv = document.getElementById('console-out');
function appendToDOM(message, type) {
var p = document.createElement('p');
p.textContent = "> " + message;
p.className = type;
outputDiv.appendChild(p);
outputDiv.scrollTop = outputDiv.scrollHeight;
}
console.log = function(message) {
oldLog.apply(console, arguments);
appendToDOM(message, 'log');
};
console.warn = function(message) {
oldWarn.apply(console, arguments);
appendToDOM(message, 'warn');
};
console.error = function(message) {
oldError.apply(console, arguments);
appendToDOM(message, 'error');
};
console.info = function(message) {
oldInfo.apply(console, arguments);
appendToDOM(message, 'info');
};
function spinner_on() {
document.getElementById("spinner").className="spinner-border";
}
function spinner_off() {
document.getElementById("spinner").className="spinner-border d-none";
}
</script>
</body>
</html>