Skip to content

Commit

Permalink
Design pages: fix userId in passkey
Browse files Browse the repository at this point in the history
userId is a private attribute and it shouldn't be stored in a public
LDAP attribute. Thus, it was decided to stop printing it and storing it
in LDAP, but I forgot to update the design. This commit fixes this
issue.

Resolves: SSSD/sssd#7165

Signed-off-by: Iker Pedrosa <[email protected]>
  • Loading branch information
ikerexxe committed Feb 6, 2024
1 parent 948c27a commit f0c0ac5
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 14 deletions.
13 changes: 3 additions & 10 deletions src/design-pages/passkey_authentication.rst
Original file line number Diff line number Diff line change
Expand Up @@ -72,13 +72,9 @@ ipapasskey from the
`ipapasskeyuser objectclass <https://freeipa.readthedocs.io/en/latest/designs/passkeys.html#ldap-schema>`__
. For any other LDAP server we use the passkey attribute.

The format for server-side credentials for the key mapping is
The format for the key mapping is
``passkey:credentialId,pemPublicKey``.

The format for
`discoverable credentials <https://developers.yubico.com/WebAuthn/WebAuthn_Developer_Guide/Resident_Keys.html>`__ for the key mapping is
``passkey:credentialId,pemPublicKey,userId``.

IPA process
+++++++++++
FreeIPA provides a direct way to register the passkey attributes to the user
Expand Down Expand Up @@ -146,10 +142,7 @@ Execute the passkey_child passing the arguments listed above. The passkey PIN
is retrieved from the PAM conversation and written to the stdin of the
forked passkey child process(Similar to ``get_p11_child_write_buffer()``).
Check the passkey_child return code, return PAM_SUCCESS or failure based on the
result and call ``pam_reply()``. If the credential is discoverable, then the
passkey_child also prints the ``userId``, and the PAM responder has to
compare it with the one provided by the LDAP server. If they match, then it can
return PAM_SUCCESS.
result and call ``pam_reply()``.

Prompting implementation
************************
Expand Down Expand Up @@ -276,7 +269,7 @@ The most basic example of a registration would be the following: ::
# sssctl passkey-exec --register --username=USERNAME --domain=DOMAIN

This outputs the key mapping data (
``passkey:credentialId,pemPublicKey,userId``) that is used as the input for the
``passkey:credentialId,pemPublicKey``) that is used as the input for the
registration in the LDAP server. In AD and other LDAP servers the output is
copied to the LDAP attribute. In FreeIPA, the key mapping can copied to the
WebUI or to a command:
Expand Down
7 changes: 3 additions & 4 deletions src/design-pages/passkey_kerberos.rst
Original file line number Diff line number Diff line change
Expand Up @@ -139,10 +139,9 @@ the components involved in it:
* The passkey returns the assertion data, which also is returned by the
passkey_child.

* The PAM responder fills the pre-authentication with the assertion data. If
the credential is discoverable, then the ``userId`` is included in the
assertion data. The PAM responder checks if it matches with the one stored in
the LDAP attribute, and it fails if they don't match.
* The PAM responder fills the pre-authentication with the assertion data. The
PAM responder checks if it matches with the one stored in the LDAP attribute,
and it fails if they don't match.

* libkrb5 send another AS-REQ but this time with the assertion in the
pre-authentication.
Expand Down

0 comments on commit f0c0ac5

Please sign in to comment.