-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdemo.fr.html
More file actions
76 lines (65 loc) · 2.75 KB
/
demo.fr.html
File metadata and controls
76 lines (65 loc) · 2.75 KB
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
<!DOCTYPE html>
<html lang="fr">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width,initial-scale=1" />
<title>Démo Cryptools AES (navigateur)</title>
<style>
body { font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial; padding: 24px; }
pre { background:#f6f8fa; padding:12px; border-radius:6px; white-space:pre-wrap; }
code { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
</style>
</head>
<body>
<h1>Démo Cryptools AES (AES-GCM + Argon2id)</h1>
<p>
Cette démo utilise le bundle <code>window.Cryptools</code>.
Assurez-vous que votre <code>bundle.min.js</code> est chargé et qu’il attache bien
<code>window.Cryptools</code>.
</p>
<pre id="output"></pre>
<script src="speedups.js"></script> <!-- charger les speedups -->
<script type="module">
import './bundle.min.js'; // <-- votre bundle qui définit window.Cryptools
const out = document.getElementById('output');
const log = (s='') => { out.textContent += String(s) + '\n'; };
out.textContent = 'démarrage…\n';
async function main() {
// Vérifie que le bundle est bien présent
if (!window.Cryptools?.AES?.encrypt || !window.Cryptools?.AES?.decrypt) {
log('❌ window.Cryptools.AES.encrypt/decrypt introuvables.');
log(' Votre bundle attache-t-il bien window.Cryptools ?');
return;
}
const msg = 'Bonjour depuis Cryptools AES 👋';
const password = 'cheval correct pile agrafe'; // (exemple de mot de passe)
log('➡️ message clair : ' + msg);
log('➡️ mot de passe : ' + password);
log('\n⏳ Attente du chargement des optimisations…');
await window.speedups_loaded;
try {
log('\n🔐 Chiffrement…');
const combinedBase64 = await window.Cryptools.AES.encrypt(msg, password);
log('✅ texte chiffré (sel+iv+chiffrement, Base64) :');
log(combinedBase64);
log('\n🔓 Déchiffrement…');
const decrypted = await window.Cryptools.AES.decrypt(combinedBase64, password);
log('✅ déchiffré : ' + decrypted);
log('✔️ aller-retour OK : ' + (decrypted === msg));
log('\n🧪 Déchiffrement avec mauvais mot de passe (devrait échouer)…');
try {
await window.Cryptools.AES.decrypt(combinedBase64, 'mauvais mot de passe');
log('⚠️ inattendu : le déchiffrement a réussi avec un mauvais mot de passe !');
} catch (e) {
log('✅ échec attendu : ' + (e && e.message ? e.message : e));
}
} catch (e) {
log('❌ erreur : ' + (e && e.message ? e.message : e));
console.error(e);
}
}
// Lancer la démo
main();
</script>
</body>
</html>