Skip to content

security: wire verifyEnvelope into the consume side + constant-time compare + reject unkeyed-when-key-set #873

@anandgupta42

Description

@anandgupta42

Found during v0.8.1 release review (Chaos Gremlin / security auditor). Pre-existing, not regressed by v0.8.1.

verifyEnvelope (verdict.ts:~196) is only called in tests — no consumer (gate decision / replay audit) actually verifies the HMAC before trusting a verdict envelope, so signing is currently produce-only (proves who-produced, not who-can-reject). Also: (1) it uses plain === string compare on the HMAC instead of crypto.timingSafeEqual; (2) when ALTIMATE_REVIEW_SIGNING_KEY is unset it falls back to an unkeyed sha256: digest that still 'verifies' — an envelope can be silently re-forged if the key is absent.

Fix: wire verifyEnvelope into the consuming/gate path; use timingSafeEqual over equal-length buffers; reject when the stored signature is the unkeyed sha256: form while a key is configured. Deferred because it needs its own design + review (signing-soundness change), not a patch-release rush.

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type
    No fields configured for issues without a type.

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions