Lucene search

K
cvelistGoCVELIST:CVE-2021-4239
HistoryDec 27, 2022 - 9:13 p.m.

CVE-2021-4239 Weak encryption and denial of service in github.com/flynn/noise

2022-12-2721:13:53
Go
www.cve.org
2
cve-2021-4239
weak encryption
denial of service
encryption vulnerability
decrypt function
nonce counter
cryptographic security

EPSS

0.001

Percentile

34.6%

The Noise protocol implementation suffers from weakened cryptographic security after encrypting 2^64 messages, and a potential denial of service attack. After 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. In 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.

CNA Affected

[
  {
    "vendor": "github.com/flynn/noise",
    "product": "github.com/flynn/noise",
    "collectionURL": "https://pkg.go.dev",
    "packageName": "github.com/flynn/noise",
    "versions": [
      {
        "version": "0",
        "lessThan": "1.0.0",
        "status": "affected",
        "versionType": "semver"
      }
    ],
    "programRoutines": [
      {
        "name": "CipherState.Encrypt"
      },
      {
        "name": "CipherState.Decrypt"
      },
      {
        "name": "symmetricState.EncryptAndHash"
      },
      {
        "name": "HandshakeState.ReadMessage"
      },
      {
        "name": "HandshakeState.WriteMessage"
      },
      {
        "name": "symmetricState.DecryptAndHash"
      }
    ],
    "defaultStatus": "unaffected"
  }
]

EPSS

0.001

Percentile

34.6%