====== std.crypto.pqc.slhdsa ======
SLH-DSA (SPHINCS+, **NIST FIPS 205**) ist ein hash-basiertes Post-Quantum-Signaturverfahren. Die Sicherheit beruht ausschließlich auf der Kollisionsresistenz von SHA-256 — keine gittertheoretischen Annahmen wie bei ML-DSA.
**Klassifikation:** Asymmetrisches, hash-basiertes Signaturverfahren. Zustandslos (stateless) — keine Signaturzähler nötig wie bei XMSS/LMS.
import std.crypto.pqc.slhdsa;
→ [[lyx_-_programmiersprache:units:crypto:pqc|std.crypto.pqc]] · [[lyx_-_programmiersprache:units:crypto:pqc:pqc|std.crypto.pqc.pqc (High-Level API)]] · [[lyx_-_programmiersprache:units:crypto|std.crypto]]
----
===== Parametersätze =====
^ Parametersatz ^ n ^ h ^ Quantensicherheit ^ SK ^ PK ^ Signatur ^ Empfehlung ^
| SLH-DSA-SHA2-128s | 16 | 63 | ~128-Bit | 64 B | 32 B | 7856 B | **Standardwahl** |
| SLH-DSA-SHA2-256s | 32 | 64 | ~256-Bit | 128 B | 64 B | 29792 B | Höchste Sicherheit |
| Mini (nicht FIPS) | 16 | 4 | — | 64 B | 32 B | 1392 B | Nur für Tests |
**Vergleich mit ML-DSA:** SLH-DSA erzeugt größere Signaturen (7856 B vs. 3293 B für ~128-Bit), hat aber kleinere Schlüssel (PK nur 32 B). Vorteil: rein hash-basierte Sicherheitsannahmen, breit konservativ.
----
===== Konstanten =====
^ Konstante ^ Wert ^ Bedeutung ^
| ''SLH_128S_SK'' | 64 | SK-Größe SLH-DSA-128s in Bytes |
| ''SLH_128S_PK'' | 32 | PK-Größe SLH-DSA-128s in Bytes |
| ''SLH_128S_SIG'' | 7856 | Signaturlänge SLH-DSA-128s in Bytes |
| ''SLH_256S_SK'' | 128 | SK-Größe SLH-DSA-256s in Bytes |
| ''SLH_256S_PK'' | 64 | PK-Größe SLH-DSA-256s in Bytes |
| ''SLH_256S_SIG'' | 29792 | Signaturlänge SLH-DSA-256s in Bytes |
| ''SLH_MINI_SIG'' | 1392 | Signaturlänge Mini-Params (nicht FIPS) |
| ''SLH_PS'' | 96 | Größe des Parameter-Blocks in Bytes |
ADRS-Typ-Codes (intern, für eigene ADRS-Konstruktionen):
''SLH_WOTS=0'', ''SLH_WOTS_PK=1'', ''SLH_TREE=2'', ''SLH_FORS_TREE=3'', ''SLH_FORS_ROOTS=4'', ''SLH_WOTS_PRF=5'', ''SLH_FORS_PRF=6''
----
===== Funktionen =====
**Parameter-Initialisierung** (muss vor KeyGen/Sign/Verify aufgerufen werden):
^ Funktion ^ Beschreibung ^
| ''SLHParams128s(ps)'' | Füllt 96-Byte-Parameterblock ps für SLH-DSA-SHA2-128s |
| ''SLHParams256s(ps)'' | Füllt 96-Byte-Parameterblock ps für SLH-DSA-SHA2-256s |
| ''SLHParamsMini(ps)'' | Füllt Parameterblock für Mini-Satz (n=16, h=4 — nur Tests, nicht FIPS-konform) |
**Schlüssel und Signatur:**
^ Funktion ^ Beschreibung ^
| ''SLHDSAKeyGen(ps, skseed, skprf, pkseed, sk, pk)'' | Erzeugt Schlüsselpaar aus drei Seeds (je n Bytes). sk: SLH_xxx_SK Bytes; pk: SLH_xxx_PK Bytes. |
| ''SLHDSASign(ps, sk, msg, mlen, optrand, sig): int64'' | Signiert msg (mlen Bytes). optrand: 0 für deterministische Signatur (empfohlen). sig: caller-alloziert mit SLH_xxx_SIG Bytes. Gibt tatsächliche Signaturlänge zurück. |
| ''SLHDSAVerify(ps, pk, msg, mlen, sig): int64'' | Verifiziert Signatur. Gibt 1 bei gültig, 0 bei ungültig. |
----
===== Verwendungsbeispiel =====
import std.crypto.pqc.slhdsa;
import std.crypto.rand;
import std.alloc;
fn main(): int64 {
// Parameter-Block initialisieren (SLH-DSA-128s)
var ps: int64 := alloc(SLH_PS);
SLHParams128s(ps);
// Seeds: skseed[16], skprf[16], pkseed[16] (n=16 für 128s)
var seeds: int64 := alloc(48);
RandBytesExact(seeds, 48);
// Schlüsselpaar erzeugen
var sk: int64 := alloc(SLH_128S_SK);
var pk: int64 := alloc(SLH_128S_PK);
SLHDSAKeyGen(ps, seeds, seeds + 16, seeds + 32, sk, pk);
// Signieren
var msg: pchar := "Hello, SLH-DSA!"c;
var m_len: int64 := 15;
var sig: int64 := alloc(SLH_128S_SIG);
var sig_len: int64 := SLHDSASign(ps, sk, msg as int64, m_len, 0, sig);
// Verifizieren
var ok: int64 := SLHDSAVerify(ps, pk, msg as int64, m_len, sig);
// ok == 1 wenn gültig
free(ps, SLH_PS); free(seeds, 48);
free(sk, SLH_128S_SK); free(pk, SLH_128S_PK);
free(sig, SLH_128S_SIG);
return 0;
}
**Hinweis:** Für den einfachsten Einstieg → [[lyx_-_programmiersprache:units:crypto:pqc:pqc|std.crypto.pqc.pqc]] verwenden (kein manuelles Parameter-Block-Management).
----
===== Sicherheitseigenschaften =====
^ Eigenschaft ^ Ergebnis ^
| NIST-Standard | FIPS 205 (2024) — offiziell standardisiert |
| Sicherheitsannahme | Nur SHA-256-Kollisionsresistenz (konservativste aller PQC-Optionen) |
| Quantensicherheit | ~128-Bit (128s) / ~256-Bit (256s) |
| Signatur-Overhead | 7856 B (128s) — größer als ML-DSA, aber kleinster Public Key (32 B) |
| Zustandslos | Ja — keine Signaturzähler nötig (anders als XMSS/LMS) |
Letzte Aktualisierung: 2026-06-08