PT-2026-43168 · Go · Github.Com/Arnika-Project/Arnika
Published
2026-05-15
·
Updated
2026-05-15
CVSS v3.1
2.8
Low
| Vector | AV:P/AC:L/PR:H/UI:R/S:U/C:L/I:L/A:N |
Summary
Three medium-severity issues in arnika affecting the UDP key-rotation protocol, PQC key file handling, and KMS TLS client. All require specific preconditions to exploit and do not allow direct code execution or immediate key extraction. A self-contained PoC is attached.
Details
-
ACK timestamp not validated:
udpserver.go:185udpClient()verifies HMAC and packet type but never checksackPkt.Timestamp. A MITM can capture one ACK, drop all subsequent DATA packets, and replay the stale ACK indefinitely. Primary advances PSK each rotation, backup stays on key 1, tunnel breaks. No PSK knowledge needed. The server side already has this check, the client does not. Fix: mirror the timestamp check already present on the server side. -
Empty PQC key file silently accepted:
repositories/pqc.go:29os.ReadFilefollows symlinks. Empty file tobase64.Decode("") = []byte{}, nil. HKDF runs on the QKD key alone while arnika logs[OK] HKDF derivation completed for QKD+PQC key. Requires write access to the directory containingPQC PSK FILE. Fix: validate decoded key is non-empty before derivation; enforce parent directory permissions inSECURITY.md. -
InsecureSkipVerify: truehardcoded:repositories/kms.go:61KMS HTTP client unconditionally setsInsecureSkipVerify: true, overridingRootCAs.CA CERTIFICATEis loaded but never consulted (dead code). Requires MITM between arnika and the KMS endpoint, which in typical deployments are co-located. Fix: remove the flag;RootCAsalready holds the correct pool whenCA CERTIFICATEis configured.
PoC
See [arnika exploit.tar.gz](https://github.com/user-attachments/files/27585454/arnika exploit.tar.gz). PoC shows observable behavior for each attack; the third one (KMS MITM) needs no custom code, any HTTPS proxy with a self-signed cert is enough.
Impact
Issues require network MITM or local directory write access to exploit. No direct key extraction or code execution. Primary impact is tunnel desync and silent security downgrade in hybrid QKD+PQC mode.
Fix
Improper Certificate Validation
Insufficient Verification of Data Authenticity
Found an issue in the description? Have something to add? Feel free to write us 👾
Related Identifiers
Affected Products
Github.Com/Arnika-Project/Arnika