wraith/backend/src
Vantz Stockwell 93811b59cb fix(security): auth hardening — httpOnly cookies, Argon2id passwords, TOTP encryption, rate limiting
C-2: JWT moved from localStorage to httpOnly cookie (eliminates XSS token theft)
C-3: WebSocket auth via short-lived single-use tickets (JWT no longer in URLs)
H-1: JWT expiry reduced from 7 days to 4 hours
H-3: TOTP secrets encrypted at rest with vault EncryptionService (auto-migrates plaintext)
H-6: Rate limiting via @nestjs/throttler (60 req/min global, tighten on auth)
H-8: Constant-time login — Argon2id verify runs against dummy hash for non-existent users
H-9: Password hashing upgraded from bcrypt(10) to Argon2id (auto-upgrades on login)
H-10: Credential list API no longer returns encrypted blobs
H-16: Admin pages use Nuxt route middleware instead of client-side guard
Plus: auth bootstrap plugin, cookie-parser middleware, all frontend Authorization headers removed

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-14 14:24:35 -04:00
..
auth fix(security): auth hardening — httpOnly cookies, Argon2id passwords, TOTP encryption, rate limiting 2026-03-14 14:24:35 -04:00
connections feat: multi-user isolation with admin/user roles 2026-03-14 12:57:38 -04:00
prisma feat: Prisma schema (7 models) + NestJS bootstrap 2026-03-12 17:06:09 -04:00
rdp fix(security): SFTP session ownership + Guacamole instruction validation 2026-03-14 14:14:31 -04:00
settings feat: settings — key/value store with CRUD API 2026-03-12 17:09:08 -04:00
terminal fix(security): terminal logging cleanup, session ownership, host key verification, shell injection opt-in 2026-03-14 14:15:23 -04:00
vault fix(security): auth hardening — httpOnly cookies, Argon2id passwords, TOTP encryption, rate limiting 2026-03-14 14:24:35 -04:00
app.module.ts fix(security): auth hardening — httpOnly cookies, Argon2id passwords, TOTP encryption, rate limiting 2026-03-14 14:24:35 -04:00
main.ts fix(security): infrastructure hardening — guacd network isolation, drop DB port, helmet, non-root container 2026-03-14 14:13:28 -04:00