mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2025-01-24 15:16:40 -06:00
Add design document
This document details authentication indicaters and kerberos ticket policies implemented in IPA. Resolves: https://pagure.io/freeipa/issue/8001 Signed-off-by: Changmin Teng <cteng@redhat.com> Reviewed-By: Alexander Bokovoy <abokovoy@redhat.com> Reviewed-By: Simo Sorce <ssorce@redhat.com> Reviewed-By: Robbie Harwood <rharwood@redhat.com>
This commit is contained in:
parent
b66e8a1ee2
commit
952dd2a50f
116
doc/designs/krb-ticket-policy.md
Normal file
116
doc/designs/krb-ticket-policy.md
Normal file
@ -0,0 +1,116 @@
|
||||
# Policies by authentication indicators
|
||||
|
||||
## Overview
|
||||
|
||||
Based on the pre-authentication mechanism a user used to acquire the credential,
|
||||
the KDC can enforce policies such as service access control,
|
||||
user authentication and ticket lifetime/reissue time policies to achieve a finer control over ticket issuance.
|
||||
|
||||
## Authentication indicators
|
||||
|
||||
Authentication indicators are attached by KDC to tickets issued to user and depend on
|
||||
which pre-authentication mechanism used to acquire the credential.
|
||||
Indicators and corresponding mechanisms are listed below:
|
||||
|
||||
| Authentication indicator | Mechanism |
|
||||
|:------------------------ | :------------------- |
|
||||
| radius | RADIUS |
|
||||
| otp | Two factor authentication (password + OTP) |
|
||||
| pkinit | PKINIT |
|
||||
| hardened | Hardened Password (by SPAKE or FAST) |
|
||||
|
||||
Hardened password means a password authentication with either SPAKE or FAST armoring enabled.
|
||||
Although it is possible to assign separate indicators to SPAKE and FAST, when both SPAKE and FAST are used,
|
||||
only the indicator for SPAKE will be applied.
|
||||
Since there is no practical reason to forbid the use of SPAKE while using FAST armoring,
|
||||
these two are assigned the same indicator to represent a brute-force hardened form of password authentication.
|
||||
|
||||
By requiring certain authentication indicators to a user, we can force a user to be authenticated with one of
|
||||
the mechanisms associated with those auth indicators to obtain a ticket.
|
||||
By defining a white list of authentication indicators to a service, we can allow a user to use the service
|
||||
only if the user obtained a ticket with at least one of those indicators included.
|
||||
|
||||
#### Note
|
||||
|
||||
For unattended services (services that is a part of the IPA core system), the authentication indicator should not be set,
|
||||
or it may break the whole system. Examples for such services are `HTTP/*` (for webUI and IPA API end-points),
|
||||
`ldap/*` (for user data management etc.), `cifs/*` (for SMB and DCE-RPC services),
|
||||
also for `host/*` on IPA masters which are used by DCE-RPC services to validate client-server communication.
|
||||
|
||||
## Available policies and user interface
|
||||
|
||||
### Connection policy
|
||||
|
||||
Different service may need different security strength and consequently requires different pre-auth mechanism.
|
||||
|
||||
e.g. must have used 2FA or OTP in order to connect to `host/securemachine@REALM`
|
||||
|
||||
Services with no authentication indicator assigned will accept tickets authenticated by any mechanism.
|
||||
|
||||
#### CLI Workflow:
|
||||
|
||||
Administrators can specify required auth indicators for a service via `ipa service-mod` command.
|
||||
|
||||
e.g. `ipa service-mod service/@REALM --auth-ind otp --auth-ind pkinit`
|
||||
|
||||
#### WebUI Workflow:
|
||||
|
||||
Administrators can specify required auth indicator on service settings page.
|
||||
As default no auth indicator is specified which means all pre-auth mechanism is accepted.
|
||||
|
||||
### Ticket lifecycle policy
|
||||
|
||||
Administrators may want to define different ticket expiration and renewal values
|
||||
as well as ticket flags based on the type of the authentication conducted.
|
||||
|
||||
e.g. the lifetime of the OTP based ticket can be longer than for a single-factor
|
||||
|
||||
Tickets without an authentication indicator will have the default lifetime / renewtime.
|
||||
|
||||
#### CLI Workflow:
|
||||
|
||||
Administrators can specify max life and renew for each auth indicator and global default via `ipa krbtpolicy-mod` command.
|
||||
|
||||
e.g. `ipa krbtpolicy-mod --setattr otp-maxlife=604800 pkinit-maxtime=604800`
|
||||
|
||||
Current `--maxlife` and `--maxrenew` options for `ipa krbtpolicy-mod` will set the default max life / renew respectively.
|
||||
|
||||
After this, the output for `ipa krbtpolicy-show` will look like:
|
||||
|
||||
```
|
||||
Max life:
|
||||
- default: 86400
|
||||
- otp: 604800
|
||||
- pkinit: 604800
|
||||
Max renew:
|
||||
- default: 604800
|
||||
```
|
||||
|
||||
#### WebUI Workflow:
|
||||
|
||||
In Policy/Kerberos Ticket Policy tab, there is a table
|
||||
where administrators can specify max renew and life for each supported auth indicator.
|
||||
|
||||
### Ticket lifetime jitter
|
||||
|
||||
Ticket lifetimes can be jittered so that renewals / re-issues do not overwhelm the KDC at a certain moment.
|
||||
The feature is enabled automatically so that we can avoid triggering an LDAP query on every `AS_REQ` and `TGS_REQ`.
|
||||
|
||||
## Implementation
|
||||
|
||||
Kerberos policy, as krb5 presents it, consists of two interfaces:
|
||||
the authentication indicator attributes and the kdcpolicy plugin.
|
||||
Authentication indicator attributes allow us to make boolean access choices
|
||||
(i.e. allow or deny service principal requests) on the KDC based on configuration in the Kerberos Database (KDB).
|
||||
The kdcpolicy plugin is a much more powerful hook, allowing refinement of the request itself rather than
|
||||
a solely boolean decision.
|
||||
|
||||
Connection Policy can be implemented with authentication indicator attribute in krb5 alone,
|
||||
but ticket lifecycle policy will require LDAP to store relations between authentication indicators
|
||||
and lifetime information. We have global ticket lifetime and renew time setting stored as attribute
|
||||
`krbmaxticketlife` and `krbmaxrenewableage` inside the `cn=$REALM,cn=kerberos,$SUFFIX` subtree,
|
||||
which represents the default lifetime policy.
|
||||
For each authentication indicator, there will be an attribute to store specific lifetime for that indicator,
|
||||
such as `krbmaxticketlifetop`, `krbmaxrenewableagepkinit`
|
||||
They are stored in the same location as default policy in LDAP.
|
||||
|
Loading…
Reference in New Issue
Block a user