PT-2026-41492 · Crates.Io · Kanidm
Publicado
2026-05-06
·
Atualizado
2026-05-06
CVSS v3.1
6.1
Média
| Vetor | AV:N/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:N |
Summary
The kanidmd web UI renders the WebAuthn passkey-registration challenge as raw JSON inside an inline
<script id="data"> element using the Askama |safe filter. The challenge embeds the account's displayname, which serde json serialises without escaping </>. A displayname containing </script> therefore terminates the script element early and injects arbitrary HTML into the credential-update page. Because the page is htmx-driven and the server's CSP allows 'unsafe-eval', injected hx-* attributes can issue authenticated same-origin API requests with the viewer's bearer cookie.Impact
An authenticated attacker who is a member of
idm people admins can write the displayname of any Person entry — including high-privilege persons — because idm acp people pii manage carries no high-privilege exclusion filter. When the targeted high-privilege user later opens Add Passkey on their own credential-update page (/ui/reset), the injected markup is swapped into the DOM and htmx fires attacker-chosen same-origin requests authenticated as the victim. This allows a helpdesk-tier operator to escalate to idm admins (e.g. by POSTing themselves into the group) or otherwise act with the victim's session. The self-write path (idm people self name write) is self-XSS only and is not counted toward impact. Even without the htmx vector, the breakout permits <meta http-equiv='refresh'> open-redirect and arbitrary defacement of the credential page.Details
- https://github.com/kanidm/kanidm/blob/master/server/core/templates/credential update add passkey partial.html#L3 — the
|safesink - https://github.com/kanidm/kanidm/blob/master/server/core/src/https/views/reset.rs#L506-L509 —
serde json::to stringof the challenge - https://github.com/kanidm/kanidm/blob/master/server/lib/src/idm/credupdatesession.rs#L2453-L2460 —
displaynameflows intostart passkey registration
Affected versions
All releases shipping the htmx credential-update views
Correção
XSS
Encontrou algum problema na descrição? Tem algo a acrescentar? Fique à vontade para nos escrever 👾
Enumeração de Fraquezas
Identificadores relacionados
Produtos afetados
Kanidm