Vulnerability description

Insufficient Session Expiration vulnerability in hexpm hexpm/hexpm ('Elixir.Hexpm.Accounts.PasswordReset' module) allows Account Takeover.

Password reset tokens generated via the "Reset your password" flow do not expire. When a user requests a password reset, Hex sends an email containing a reset link with a token. This token remains valid indefinitely until used. There is no time-based expiration enforced.

If a user's historical emails are exposed through a data breach (e.g., a leaked mailbox archive), any unused password reset email contained in that dataset could be used by an attacker to reset the victim's password. The attacker does not need current access to the victim's email account, only access to a previously leaked copy of the reset email.

This vulnerability is associated with program files lib/hexpm/accounts/password_reset.ex and program routines 'Elixir.Hexpm.Accounts.PasswordReset':can_reset?/3.

This issue affects hexpm: from 617e44c71f1dd9043870205f371d375c5c4d886d before bb0e42091995945deef10556f58d046a52eb7884.

Affected

pkg:github/hexpm/hexpm

Module Source File Routine
Hexpm.Accounts.PasswordReset lib/hexpm/accounts/password_reset.ex Hexpm.Accounts.PasswordReset.can_reset?/3
Status Type Version Changes / Fixed in
affected git 617e44c71f1d < bb0e42091995

hexpm / hex.pm

Status Type Version Changes / Fixed in
affected date 2025-08-01 < 2026-03-05

Workarounds

Users who suspect email exposure should:

  • Immediately reset their password.
  • Enable and enforce 2FA.

There is no complete mitigation without implementing token expiration.

References

Credits

  • Finder: Michael Lubas / Paraxial.io
  • Remediation developer: Jonatan Männchen / EEF
  • Remediation reviewer: Eric Meadows-Jönsson / Hex.pm

CVE record as JSON:  GET /cves/CVE-2026-21622.json
OSV record as JSON:  GET /osv/EEF-CVE-2026-21622.json