{"id":"GO-2022-0425","summary":"Weak encryption and denial of service in github.com/flynn/noise","details":"The Noise protocol implementation suffers from weakened cryptographic security after encrypting 2^64 messages, and a potential denial of service attack.\n\nAfter 2^64 (~18.4 quintillion) messages are encrypted with the Encrypt function, the nonce counter will wrap around, causing multiple messages to be encrypted with the same key and nonce.\n\nIn a separate issue, the Decrypt function increments the nonce state even when it fails to decrypt a message. If an attacker can provide an invalid input to the Decrypt function, this will cause the nonce state to desynchronize between the peers, resulting in a failure to encrypt all subsequent messages.","aliases":["CVE-2021-4239","GHSA-6cr6-fmvc-vw2p","GHSA-g9mp-8g3h-3c5c"],"modified":"2026-03-17T04:18:58.104346Z","published":"2022-02-15T01:57:18Z","database_specific":{"review_status":"REVIEWED","url":"https://pkg.go.dev/vuln/GO-2022-0425"},"references":[{"type":"FIX","url":"https://github.com/flynn/noise/pull/44"}],"affected":[{"package":{"name":"github.com/flynn/noise","ecosystem":"Go","purl":"pkg:golang/github.com/flynn/noise"},"ranges":[{"type":"SEMVER","events":[{"introduced":"0"},{"fixed":"1.0.0"}]}],"ecosystem_specific":{"imports":[{"symbols":["CipherState.Decrypt","CipherState.Encrypt","HandshakeState.ReadMessage","HandshakeState.WriteMessage","symmetricState.DecryptAndHash","symmetricState.EncryptAndHash"],"path":"github.com/flynn/noise"}]},"database_specific":{"source":"https://vuln.go.dev/ID/GO-2022-0425.json"}}],"schema_version":"1.7.5"}