From Fedora Project Wiki
No edit summary
 
(56 intermediate revisions by 4 users not shown)
Line 1: Line 1:
{{header|design}}
= About this Document =
= About this Document =


Line 7: Line 8:
! Notes
! Notes
|-
|-
| Version 2 (This page)
| Version 5 (this page)
| 15 February 2010
| 30 March 2010
| Changelog:
|
* updated the LDAP/Kerb, LDAP/LDAP, FreeIPA/Kerb, FreeIPA/LDAP screens - added a 'allow self-signed LDAP server certificates' checkbox. This is to address [https://bugzilla.redhat.com/show_bug.cgi?id=578231 bug 578231] that was found during the [[Test_Day:2010-03-30_SSSDByDefault | SSSD By Default]] test day on 30 March 2010.
|-
| [[Design/SSSD/Version4 | Version 4]]
| 11 March 2010
|
* moved the revert button to the left
* changed right icons to be 'apply' and 'cancel'
* added FreeIPA account database method and screen
* added GTK info bar for secure LDAP authentication
* note that LDAP auth is not available for FreeIPA - in the interest of keeping the UI simpler and easier-to-use (it's not a common use case)
* added [[#Testing_User_Input_Before_Committing | authentication testing screen workflow]] ('''for later implementation''')
|-
| [[Design/SSSD/Version3 | Version 3]]
| 18 February 2010
|
* Changed "User Account Storage" to "User Account Database"
* Changed "Advanced Settings" to "Advanced Options"
* Now uses the word 'password' - not just for Kerberos password, but also LDAP password, NIS password, Winbind password
* in the Create home directories for centrally-managed users...  checkbox, we dropped the "centrally-managed" word because the setting does not differentiate between centrally-managed and local users.
* Dropped "Cache user information" from the UI completely because with sssd caching and nscd caching there could be unexpected results.
|-
| [[Design/SSSD/Version2 | Version 2]]
| 15 February 2010, updated 17 February 2010
| Now we have a single UI that integrates both SSSD and legacy functionality. One issue - only one domain visible at a time. Updated 17 Feb to better address smartcard usage.
|-
|-
| [https://fedoraproject.org/w/index.php?title=Design/SSSD&oldid=151637 Version 1]
| [https://fedoraproject.org/w/index.php?title=Design/SSSD&oldid=151637 Version 1]
Line 16: Line 41:
|}
|}


= Mockups =
== Mockup Sources ==
*Inkscape source for all mockups is available:
** [[Media:sysconfig-auth-mockups-draft5.svg | Download Inkscape SVG]] - for the sys-config-auth ui bits
** [[Media:sysconfig-auth-mockups-draft2-firstboot.svg | Download Inkscape SVG]] - for the firstboot screen
== Things To Note About These Mockups ==
* '''Access Keys have not been addressed in these mockups''' - but they'll need to be there
* For the '''smart card''' components to show up (as in the current implementation) the following components need to be installed:
** coolkey
** ccid
** nss-tools
** ifd-egate
** pcsc-lite
* For the '''NIS''' components to show up (as in the current implementation) the following components need to be installed:
** yp-tools
** ypbind
* [[#A_Note_About_Checking_For_User_Errors | As noted above]], the user-error checks are a suggestion and not a requirement.
== Identity & Authentication Tab ==
=== Paths Through the Tab ===
{| class="wikitable"
|-
! Path ID Number
! Identity Technology
! Authentication Technology
! Backend technology
! Mockup
|-
| 0
| Local accounts only
| Password
| Not Applicable
| [[#Path_0:_Local_accounts_only |View Mockup]]
|-
| 1
| LDAP
| Kerberos
| SSSD
| [[#Path_1:_LDAP.2FKerberos |View Mockup]]
|-
| 2
| LDAP
| LDAP
| SSSD
| [[#Path_2:_LDAP.2FLDAP |View Mockup]]
|-
| 3
| FreeIPA
| Kerberos
| SSSD
| [[#Path_3:_FreeIPA.2FKerberos |View Mockup]]
|-
| 4
| FreeIPA
| LDAP
| SSSD
| [[#Path_4:_FreeIPA.2FLDAP |View Mockup]]
|-
| 5
| NIS
| NIS
| Legacy
| [[#Path_5:_LDAP.2FLDAP |View Mockup]]
|-
| 6
| NIS
| Kerberos
| Legacy
| [[#Path_6:_NIS.2FKerberos |View Mockup]]
|-
| 7
| Winbind
| Winbind
| Legacy
| [[#Path_7:_Winbind.2FWinbind |View Mockup]]
|}
=== Mockups By Path ===
==== Path 0: Local accounts only ====
[[Image:sysconfig-auth-mockups-draft54-localonly.png]]
[[#Mockups | Back to Mockups List]]
==== Path 1: LDAP/Kerberos ====
Can we check to make sure the server exists and is contact-able?
[[Image:sysconfig-auth-mockups-draft5-1ldapkrb.png]]
[[#Mockups | Back to Mockups List]]
==== Path 2: LDAP/LDAP ====
[[Image:sysconfig-auth-mockups-draft5-2ldapldap.png]]
[[#Mockups | Back to Mockups List]]
==== Path 3: FreeIPA/Kerberos ====
[[Image:sysconfig-auth-mockups-draft5-3freeipakerb.png]]
[[#Mockups | Back to Mockups List]]
==== Path 4: FreeIPA/LDAP ====
[[Image:sysconfig-auth-mockups-draft5-4freeipaldap.png]]
[[#Mockups | Back to Mockups List]]
==== Path 5: NIS/NIS ====
[[Image:sysconfig-auth-mockups-draft5-5nisnis.png]]
[[#Mockups | Back to Mockups List]]
==== Path 6: NIS/Kerberos ====
[[Image:sysconfig-auth-mockups-draft5-6niskrb.png]]
[[#Mockups | Back to Mockups List]]
==== Path 7: Winbind/Winbind ====
[[Image:sysconfig-auth-mockups-draft5-7winbindwinbind.png]]
[[#Mockups | Back to Mockups List]]
=== Dropdown Items ===
==== User Account Storage Dropdown====
* For the '''User Account Configuration''' > '''User Account Storage''' dropdown, the following fields should appear:
** LDAP
** NIS (if yp-tools && ypbind installed)
** Winbind
** Smartcard (if coolkey, ecid, nss-tools, ifd-egate, pcsc-lite installed)
==== Authentication Method Dropdown ====
* If user does not want to configure centrally-managed accounts and has never configured it before, '''Local accounts only''' will be selected under '''User Account Storage''' and only 'Password' will be available under '''Authentication Configuration.'''
* If '''LDAP''' is selected under '''User Account Storage''', only the following options should be available under '''Authentication Configuration''' > '''Authentication Method''':
** LDAP
** Kerberos
* If '''NIS''' is selected under '''User Account Storage''', only the following options should be available under '''Authentication Configuration''' > '''Authentication Method''':
** NIS
** Kerberos
* If '''Winbind''' is selected under '''User Account Storage''', only the following options should be available under '''Authentication Configuration''' > '''Authentication Method''':
** Winbind
Smart cards will be handled in the 'Advanced Options' tab as they apply to both local and centrally-managed accounts.
'''Diagram for your convenience:'''
+ Local accounts only
|
|-- Password
|
+ LDAP
|
|-- LDAP (requires ldaps or TLS)
|
|-- Kerberos
|
+ Free IPA
|
|-- Kerberos
|
+ NIS
|
|-- NIS
|
|-- Kerberos
|
+ Winbind
|
|-- Winbind
== Firstboot ==
[[Image:sysconfig-auth-mockups-draft2-firstboot.png]]
== Advanced Options Tab ==
Smartcards will be set up via 'advanced options.'
[[Image:sysconfig-auth-mockups-draft5-advancedoptions.png]]
[[Image:sysconfig-auth-mockups-draft5-advancedoptions2.png]]
== Testing User Input Before Committing ==
This is proposed for later on.
=== Scenarios ===
==== Scenario 1: User Successfully Authenticates ====
{| class="wikitable"
|-
! Step
! Screen
! Description
! Mockup
|-
| 1
| Base screen
| User fills out details of their identity/auth setup and decides to apply them. He or she hits 'Apply.'
| [[#Main_Window |View Mockup]]
|-
| 2
| Initial Auth Window
| User types in their credentials and hits 'test settings.'
| [[#Authentication_Dialog |View Mockup]]
|-
| 3
| Authentication Spinner Window
| User waits for the system to attempt to authenticate them.
| [[#Authentication_Spinner |View Mockup]]
|-
| 4
| Authentication Success
| User clicks 'commit changes' as their authentication worked. Both this window and the base screen window disappear. They're done.
| [[#Authentication_Success |View Mockup]]
|}
==== Scenario 2: User Authentication Fails ====
{| class="wikitable"
|-
! Step #
! Screen
! Description
! Mockup
|-
| 1
| Base screen
| User fills out details of their identity/auth setup and decides to apply them. He or she hits 'Apply.'
| [[#Main_Window |View Mockup]]
|-
| 2
| Initial Auth Window
| User types in their credentials and hits 'test settings.'
| [[#Authentication_Dialog |View Mockup]]
|-
| 3
| Authentication Spinner Window
| User waits for the system to attempt to authenticate them.
| [[#Authentication_Spinner |View Mockup]]
|-
| 4
| Authentication Failure
| User may attempt to type password again and re-authenticate. In this case they hit 'test settings' and go back to step 3. The user may decide to give up, in which case they press cancel. This window disappears.
| [[#Authentication_Failure |View Mockup]]
|-
| 5
| Base screen
| User hits cancel on the base window, or modifies the settings and hits 'Apply' again. Return to step 2.
| [[#Main_Window |View Mockup]]
|}
=== Mockups ===
==== Main Window ====
[[Image:sysconfig-auth-mockups-draft4-testing-mainwindow.png]]
==== Authentication Dialog ====
[[Image:sysconfig-auth-mockups-draft4-testing-auth.png]]
==== Authentication Spinner ====
[[Image:sysconfig-auth-mockups-draft4-testing-authspinner.png]]
==== Authentication Success ====
[[Image:sysconfig-auth-mockups-draft4-testing-authsuccess.png]]
==== Authentication Failure ====
[[Image:sysconfig-auth-mockups-draft4-testing-authfailure.png]]


= About this Project =
= About this Project =
Line 36: Line 337:
* Design a new UI for setting SSSD configuration.
* Design a new UI for setting SSSD configuration.
* Enable users to still use the old UI for functionality not supported by SSSD/
* Enable users to still use the old UI for functionality not supported by SSSD/
* Avoid revisiting the design of the old UI as we do not have developer resources and time to do this right now.
* <strike>Avoid revisiting the design of the old UI as we do not have developer resources and time to do this right now.</strike>  It's the best solution so we are proposing it anyway.
* Guide users to the right UI for the job even though the criteria by which we determine the right UI for them are confusing and inconsistent.
* Guide users to the right UI for the job even though the criteria by which we determine the right UI for them are confusing and inconsistent.


Line 70: Line 371:


=== Story 1: Fresh Install, Local Only User ===
=== Story 1: Fresh Install, Local Only User ===
# User downloads a copy of Fedora from www.fedoraproject.org.
# User installs Fedora using the default settings.
# User boots machine and encounters firstboot.
# User encounters the 'create user' screen of firstboot. He or she is advised that if they need to set up centrally-managed logins, they'll need to click the 'use centrally-managed login' button (We'll avoid the use of the word 'network' since is more vague than 'centrally-managed' for local-only users.)
# '''The user might click on the 'use centrally-managed login' button and get the system-config-auth dialog with two tabs in it, but hopefully will quickly realize it's not meant for them to use and close the dialog, continuing on with firstboot.'''
# The user will log into the desktop without issue.
# Ideally, at this point, System > Administration > Authentication will not be available. If it is, the user may open this up through exploration or by accident and encounter the UI there as well.


=== Story 2: Fresh Install, Single-Domain User ===
=== Story 2: Fresh Install, Single-Domain User ===
# User downloads a copy of Fedora from www.fedoraproject.org.
# User installs Fedora using the default settings. They set up a local root account here.
# User boots machine and encounters firstboot.
# User encounters the 'create user' screen of firstboot. He or she is advised that if they need to set up centrally-managed logins, they'll need to click the 'use centrally-managed login' button (We'll avoid the use of the word 'network' since is more vague than 'centrally-managed' for local-only users.)
# User clicks the 'use centrally managed login' button and selects the combination of identity & auth settings they need to based on the technology on their network rather than sssd/legacy split. Depending on the choices the user makes, either sssd will be enabled or the legacy stack will be used.
#* What if the user doesn't know what technology the server uses? They'd be in a bind regardless of the design here - they need this information to be able to set any of this up. We assume it's provided by their helpdesk.
#* '''The user may be anxious to set up a non-root local account. Should there be a tooltip informing them they may do so later by logging in as root and using System > Administration > Users and Groups??'''
#* '''User cannot log in as root to use to System > Administration > Users and Groups to set up a local non-root account - root logins are disabled.'''
# The user finishes firstboot, and attempts to log into their system.
# Centrally-managed login works. Yay! All is good.
# Centrally-managed login fails. Darn! What went wrong?
#* Is there network access? (does GDM ask this troubleshooting question?)
#* Did the user set something up incorrectly? (does GDM suggest logging in as root and going to the auth ui to fix?)
==== Discussion ====
* This user may be concerned at this point about setting up a local account. They have root already by this time, that's set up in the install program. We could tell the user to log in as root and set up a local account on the command-line, or we could let them create the local account right here (latter is more convenient.) However, that convenience may come at the expense of some convenience for the vast majority of Fedora users.


=== Story 3: Fresh Install, Multi-Domain User ===
=== Story 3: Fresh Install, Multi-Domain User ===
# User downloads a copy of Fedora from www.fedoraproject.org.
# User installs Fedora using the default settings. They set up a local root account here.
# User boots machine and encounters firstboot.
# User encounters the 'create user' screen of firstboot. He or she is advised that if they need to set up centrally-managed logins, they'll need to click the 'use centrally-managed login' button (We'll avoid the use of the word 'network' since is more vague than 'centrally-managed' for local-only users.)
# User clicks the 'use centrally managed login' button and selects the combination of identity & auth settings they need to based on the technology on their network rather than sssd/legacy split. Depending on the choices the user makes, either sssd will be enabled or the legacy stack will be used.
# The user finishes firstboot, and attempts to log into their system.
# Centrally-managed login works. Yay! All is good.
# User manually edits configuration files to configure a second domain.


=== Story 4: Pre-configured Centrally-Managed Desktop ===
=== Story 4: Pre-configured Centrally-Managed Desktop ===
# User receives a company-issued desktop with Fedora or RHEL pre-installed on it.
# This laptop is pre-configured to log them into the corporate network. They turn it on and attempt to log into their system using credentials provided by their employer.
#* Centrally-managed login works. Yay! All is good.
#* Centrally-managed login fails. Darn! What went wrong?
# Let's assume it worked.
# User clicks on System > Administration > Authentication (for legacy) or System > Administration > Centrally-Managed Authentication (SSSD ui). Prompted for root password.
#* If they have root, they can see the settings '''for the first domain only''' populated in the UI.
#* If they don't have root, they don't open the UI.


== What login/authentication methods does SSSD support? What methods are supported by the legacy system? ==
== What login/authentication methods does SSSD support? What methods are supported by the legacy system? ==
Line 81: Line 421:
=== SSSD ===
=== SSSD ===
For looking up user accounts on the network, SSSD supports:
For looking up user accounts on the network, SSSD supports:
* LDAP servers (including POSIX-friendly Active Directory servers)
* LDAP servers - meaning RFC2307, OpenLDAP, 389, perhaps SunONE
* [http://freeipa.org IPA servers]
* [http://freeipa.org IPA servers] - meaning RFC2307bis
 
Where do POSIX-friendly Active Directory servers go?


NIS will be supported in the future.
NIS will be supported in the future.
Line 90: Line 432:
* LDAP passwords
* LDAP passwords
* [http://freeipa.org IPA] passwords
* [http://freeipa.org IPA] passwords
Winbind is supported using the legacy stack. Winbind effectively means using Samba to join the machine into an Active Directory domain.
If a user does not want to join the machine but rather use AD as yet another LDAP server and use AD KDC as authentication server she can do it, but for it she would have to get into the sssd configuration manually and set XYZ there.


=== Legacy System ===
=== Legacy System ===
Line 97: Line 443:
== A Note About Offline Authentication ==
== A Note About Offline Authentication ==


(If I understand correctly, this may be wrong, please correct --[[User:Duffy|Duffy]] 01:30, 10 February 2010 (UTC)) Servers have policies that enforce how often a user may log in while offline without connecting to the authentication server, and can set when that cache expires. Client-side, you can also enable or disable offline login and how old the cache is allowed to get before the user must connect to the server. The server settings, of course, always override what you can set on the client. If the server says your cache will only last 3 days for offline, and you set it to expire after 99 years client-side - the server setting is going to trump the client setting.
ervers have policies that enforce how often a user may log in while offline without connecting to the authentication server, and can set when that cache expires. Client-side, you can also enable or disable offline login and how old the cache is allowed to get before the user must connect to the server. The server settings, of course, always override what you can set on the client. If the server says your cache will only last 3 days for offline, and you set it to expire after 99 years client-side - the server setting is going to trump the client setting. The client-side enforcement is easily gotten-around by a user with root. It's really not there to prevent a user from logging in to their local machine. Truthfully, it's real purpose is to provide two things, when it's configured correctly (i.e. set up to expire at least somewhat before the server-side enforcement expires).
 
# It will notify the user when they authenticate (by way of a PAM message) that their local credentials are only valid for N more days. This provides the end-user some feedback to know how often they need to check in with the main systems.
# If configured as I mentioned before, with the expiration occurring a reasonable amount of time before the server-side lockout, it provides users the ability to recover their credentials without having to contact the helpdesk and have the account unlocked. They just come into the office or attach to the VPN by other means and perform an online login. This has the dual effect, then, of refreshing their local credentials as well as resetting the timeout for the server-side enforcement.


These policies are meant mainly to require users to 'phone home' frequently enough to stay in compliance with account policies - for example, so the user will hit forced password changes. To the user, though, expiration means that until the user can connect to the appropriate network, they are effectively locked out of their account on their machine.
These policies are meant mainly to require users to 'phone home' frequently enough to stay in compliance with account policies - for example, so the user will hit forced password changes. To the user, though, expiration means that until the user can connect to the appropriate network, they are effectively locked out of their account on their machine.


There is a tension here between the central system administrators' need to enforce their policies and the end users' need to be able to log into their system and get work done. Since the server policies trump the client-side policies anyway, I suggest to always set the client to enable offline login, with a cache that has an indefinite lifetime. In situations where this is unacceptable, clients may be deployed with a different default configuration. Also, the server would override the setting anyway.
There is a tension here between the central system administrators' need to enforce their policies and the end users' need to be able to log into their system and get work done. Since the server policies trump the client-side policies anyway, I suggest to always set the client to enable offline login, with a cache that has an indefinite lifetime. In situations where this is unacceptable, clients may be deployed with a different default configuration. Also, the server would override the setting anyway.
The way that server-side enforcement of a mandatory connection time works, is that if the system doesn't check in for X days, the server will automatically disable their network credentials. This means that even if the client does come back and try to auth after this time, they will be unable to gain access to network resources until they've called their helpdesk/IT department and had their account unlocked.
== A Note About Checking For User Errors ==
A situation that could have an extremely negative impact on the user experience here is if the user fills out the screen in such a manner that they lock themselves out of being able to log into their computer. When the users are locked out, and sitting at GDM trying to log in, we can't really know why exactly they are unable to log in (they could honestly be mistyping their password, or they could have goofed up the url for their LDAP server.)
We want to try to minimize the chances the users end up in that locked-out scenario. I've added little icons / messages throughout these mockups here to suggest that preventing user error up front, by checking to see that entered URLs are valid '''at the time they are entered, before the user is locked'''. It is understood that in some cases the ability to check for these things is not possible, not reliably possible, or would require effort well beyond the scope of the changes being made to the dialog now. That's completely cool. I think it is good food for thought though, to consider whether or not this is a good mechanism to minimize our users' chances of getting locked out of their own machine.
One note about these little checks - if some of the resources the user inputs are on a VPN, as Stephen Gallagher pointed out, the user is unable to connect to VPN during firstboot when this dialog first appears, so a valid URL on a VPN network you're not connected to will indeed fail. To account for that case the messages could use language to reflect, 'we can't contact this resource now' or some other solution could be worked out. So please consider this aspect of the mockups a suggestion that could definitely be improved upon.


= Current UI =
= Current UI =
Line 120: Line 480:
Image:Sysconfauth-legacy-nis.png | NIS settings
Image:Sysconfauth-legacy-nis.png | NIS settings
</gallery>
</gallery>
= Mockups =
== Things To Note About These Mockups ==
*Inkscape source for all mockups is available:
** [[Media:sysconfig-auth-mockups-draft2.svg | Download Inkscape SVG]]
* '''Access Keys have not been addressed in these mockups''' - but they'll need to be there
* For the '''smart card''' components to show up (as in the current implementation) the following components need to be installed:
** coolkey
** ecid
** nss-tools
** ifd-egate
** pcsc-lite
* For the '''MIS''' components to show up (as in the current implementation) the following components need to be installed:
** yp-tools
** ypbind
== Identity & Authentication Tab ==
=== Dropdown Items ===
==== User Account Storage Dropdown====
* For the '''User Account Configuration''' > '''User Account Storage''' dropdown, the following fields should appear:
** LDAP
** NIS (if yp-tools && ypbind installed)
** Winbind
** Smartcard (if coolkey, ecid, nss-tools, ifd-egate, pcsc-lite installed)
==== Authentication Method Dropdown ====
* If '''LDAP''' is selected under '''User Account Storage''', only the following options should be available under '''Authentication Configuration''' > '''Authentication Method''':
** LDAP
** Kerberos
* If '''NIS''' is selected under '''User Account Storage''', only the following options should be available under '''Authentication Configuration''' > '''Authentication Method''':
** NIS
** Kerberos
* If '''Winbind''' is selected under '''User Account Storage''', only the following options should be available under '''Authentication Configuration''' > '''Authentication Method''':
** Winbind
* If '''Smartcard''' is selected under '''User Account Storage''', only the following options should be available under '''Authentication Configuration''' > '''Authentication Method''':
** Smartcard
** Kerberos
'''Diagram for your convenience:'''
- LDAP
  '-- LDAP
  '-- Kerberos
- NIS
  '-- NIS
  '-- Kerberos
- Winbind
  '-- Winbind
- Smartcard
  '-- Smartcard
  '-- Kerberos
=== Paths Through the Tab ===
{| class="wikitable"
|-
! Path ID Number
! Identity Technology
! Authentication Technology
! Backend technology
! Mockup
|-
| 1
| LDAP
| Kerberos
| SSSD
| [[#Path_1:_LDAP.2FKerberos |View Mockup]]
|-
| 2
| LDAP
| LDAP
| SSSD
| [[#Path_2:_LDAP.2FLDAP |View Mockup]]
|-
| 3
| NIS
| NIS
| Legacy
| [[#Path_2:_LDAP.2FLDAP |View Mockup]]
|-
| 4
| NIS
| Kerberos
| Legacy
| [[#Path_4:_NIS.2FKerberos |View Mockup]]
|-
| 5
| Winbind
| Winbind
| Legacy
| [[#Path_5:_Winbind.2FWinbind |View Mockup]]
|-
| 6
| Smartcard
| Smartcard
| Legacy
| [[#Path_6:_Smartcard.2FSmartcard |View Mockup]]
|-
| 7
| Smartcard
| Kerberos
| Legacy
|[[#Path_7:_Smartcard.2FKerberos |View Mockup]]
|}
=== Mockups By Path ===
=== Path 1: LDAP/Kerberos ===
[[Image:sysconfig-auth-mockups-draft2-1ldapkrb.png]]
[[#Mockups | Back to Mockups List]]
=== Path 2: LDAP/LDAP ===
[[Image:sysconfig-auth-mockups-draft2-2ldapldap.png]]
[[#Mockups | Back to Mockups List]]
=== Path 3: NIS/NIS ===
[[Image:sysconfig-auth-mockups-draft2-3nisnis.png]]
[[#Mockups | Back to Mockups List]]
=== Path 4: NIS/Kerberos ===
[[Image:sysconfig-auth-mockups-draft2-4niskrb.png]]
[[#Mockups | Back to Mockups List]]
=== Path 5: Winbind/Winbind ===
[[Image:sysconfig-auth-mockups-draft2-5winbindwinbind.png]]
[[#Mockups | Back to Mockups List]]
=== Path 6: Smartcard/Smartcard ===
[[Image:sysconfig-auth-mockups-draft2-6smartcardsmartcard.png]]
[[#Mockups | Back to Mockups List]]
=== Path 7: Smartcard/Kerberos ===
[[Image:sysconfig-auth-mockups-draft2-7smartcardkerberos.png]]
[[#Mockups | Back to Mockups List]]
== Advanced Options Tab ==
[[Image:sysconfig-auth-mockups-draft2-advancedoptions.png]]

Latest revision as of 20:42, 26 August 2013

About this Document

Version Date Notes
Version 5 (this page) 30 March 2010
  • updated the LDAP/Kerb, LDAP/LDAP, FreeIPA/Kerb, FreeIPA/LDAP screens - added a 'allow self-signed LDAP server certificates' checkbox. This is to address bug 578231 that was found during the SSSD By Default test day on 30 March 2010.
Version 4 11 March 2010
  • moved the revert button to the left
  • changed right icons to be 'apply' and 'cancel'
  • added FreeIPA account database method and screen
  • added GTK info bar for secure LDAP authentication
  • note that LDAP auth is not available for FreeIPA - in the interest of keeping the UI simpler and easier-to-use (it's not a common use case)
  • added authentication testing screen workflow (for later implementation)
Version 3 18 February 2010
  • Changed "User Account Storage" to "User Account Database"
  • Changed "Advanced Settings" to "Advanced Options"
  • Now uses the word 'password' - not just for Kerberos password, but also LDAP password, NIS password, Winbind password
  • in the Create home directories for centrally-managed users... checkbox, we dropped the "centrally-managed" word because the setting does not differentiate between centrally-managed and local users.
  • Dropped "Cache user information" from the UI completely because with sssd caching and nscd caching there could be unexpected results.
Version 2 15 February 2010, updated 17 February 2010 Now we have a single UI that integrates both SSSD and legacy functionality. One issue - only one domain visible at a time. Updated 17 Feb to better address smartcard usage.
Version 1 10 February 2010 Initial cut; had concept of a new UI and an old UI.

Mockups

Mockup Sources

Things To Note About These Mockups

  • Access Keys have not been addressed in these mockups - but they'll need to be there
  • For the smart card components to show up (as in the current implementation) the following components need to be installed:
    • coolkey
    • ccid
    • nss-tools
    • ifd-egate
    • pcsc-lite
  • For the NIS components to show up (as in the current implementation) the following components need to be installed:
    • yp-tools
    • ypbind
  • As noted above, the user-error checks are a suggestion and not a requirement.

Identity & Authentication Tab

Paths Through the Tab

Path ID Number Identity Technology Authentication Technology Backend technology Mockup
0 Local accounts only Password Not Applicable View Mockup
1 LDAP Kerberos SSSD View Mockup
2 LDAP LDAP SSSD View Mockup
3 FreeIPA Kerberos SSSD View Mockup
4 FreeIPA LDAP SSSD View Mockup
5 NIS NIS Legacy View Mockup
6 NIS Kerberos Legacy View Mockup
7 Winbind Winbind Legacy View Mockup

Mockups By Path

Path 0: Local accounts only

Back to Mockups List

Path 1: LDAP/Kerberos

Can we check to make sure the server exists and is contact-able?

Back to Mockups List

Path 2: LDAP/LDAP

Back to Mockups List

Path 3: FreeIPA/Kerberos

Back to Mockups List

Path 4: FreeIPA/LDAP

Back to Mockups List

Path 5: NIS/NIS

Back to Mockups List

Path 6: NIS/Kerberos

Back to Mockups List

Path 7: Winbind/Winbind

Back to Mockups List


Dropdown Items

User Account Storage Dropdown

  • For the User Account Configuration > User Account Storage dropdown, the following fields should appear:
    • LDAP
    • NIS (if yp-tools && ypbind installed)
    • Winbind
    • Smartcard (if coolkey, ecid, nss-tools, ifd-egate, pcsc-lite installed)

Authentication Method Dropdown

  • If user does not want to configure centrally-managed accounts and has never configured it before, Local accounts only will be selected under User Account Storage and only 'Password' will be available under Authentication Configuration.
  • If LDAP is selected under User Account Storage, only the following options should be available under Authentication Configuration > Authentication Method:
    • LDAP
    • Kerberos
  • If NIS is selected under User Account Storage, only the following options should be available under Authentication Configuration > Authentication Method:
    • NIS
    • Kerberos
  • If Winbind is selected under User Account Storage, only the following options should be available under Authentication Configuration > Authentication Method:
    • Winbind

Smart cards will be handled in the 'Advanced Options' tab as they apply to both local and centrally-managed accounts.

Diagram for your convenience:

+ Local accounts only
|
|-- Password
|
+ LDAP
|
|-- LDAP (requires ldaps or TLS)
|
|-- Kerberos
|
+ Free IPA
|
|-- Kerberos
|
+ NIS
|
|-- NIS
|
|-- Kerberos
|
+ Winbind
|
|-- Winbind

Firstboot


Advanced Options Tab

Smartcards will be set up via 'advanced options.'


Testing User Input Before Committing

This is proposed for later on.

Scenarios

Scenario 1: User Successfully Authenticates

Step Screen Description Mockup
1 Base screen User fills out details of their identity/auth setup and decides to apply them. He or she hits 'Apply.' View Mockup
2 Initial Auth Window User types in their credentials and hits 'test settings.' View Mockup
3 Authentication Spinner Window User waits for the system to attempt to authenticate them. View Mockup
4 Authentication Success User clicks 'commit changes' as their authentication worked. Both this window and the base screen window disappear. They're done. View Mockup

Scenario 2: User Authentication Fails

Step # Screen Description Mockup
1 Base screen User fills out details of their identity/auth setup and decides to apply them. He or she hits 'Apply.' View Mockup
2 Initial Auth Window User types in their credentials and hits 'test settings.' View Mockup
3 Authentication Spinner Window User waits for the system to attempt to authenticate them. View Mockup
4 Authentication Failure User may attempt to type password again and re-authenticate. In this case they hit 'test settings' and go back to step 3. The user may decide to give up, in which case they press cancel. This window disappears. View Mockup
5 Base screen User hits cancel on the base window, or modifies the settings and hits 'Apply' again. Return to step 2. View Mockup


Mockups

Main Window

Authentication Dialog

Authentication Spinner

Authentication Success

Authentication Failure

About this Project

What is SSSD?

SSSD (an acronym for 'System Security Services Daemon') is a Fedora Hosted free software project that aims to provide access to identity and authentication remote resource through a common framework that can provide caching and offline support to the system. It provides PAM and NSS modules, as well as D-BUS based interfaces. It provides also a better database to store local users as well as extended user data.

What is system-config-auth?

System-config-auth is a GUI utility used to set up both local and network authentication (user logins) to the system it runs on. The current legacy UI is very old. SSSD, a new system, is a much better technical solution to managing authentication than the legacy system. However, SSSD does not yet support as many authentication methods as the legacy system.

The legacy system is best classified as a set of cobbled-together technology pieces, while SSSD is more integrated.

What is the design problem?

We have a new developing technology, SSSD, to manage authentication and need to provide a UI design to help desktop users to configure authentication for their systems. There is a legacy UI in place to do this though - system-config-auth - and it is difficult-to-use. However, the old UI supports some functionality that has not been implemented in SSSD yet.

The challenges here are:

  • Design a new UI for setting SSSD configuration.
  • Enable users to still use the old UI for functionality not supported by SSSD/
  • Avoid revisiting the design of the old UI as we do not have developer resources and time to do this right now. It's the best solution so we are proposing it anyway.
  • Guide users to the right UI for the job even though the criteria by which we determine the right UI for them are confusing and inconsistent.

Who is meant to use this UI?

First of all, these UIs are both accessible to users who have root-level access to the system in question. We restrict our target users to those users who administer their own system enough to have acquired root access. Users whose system is administered by someone else will have this setup already configured for them.

Secondly, while it is possible an administrator could use ssh -Y to connect to this configuration UI on remote servers with X & GTK+ installed, it is assumed that this tool will primarily be run on the system it is being used to configure. Therefore, we're assuming a desktop workstation with a monitor or a laptop, and that the user is sitting in front of the system.

Next, let's talk a little bit about system authentication. This application is targeted for users who use network-based / centrally-managed configuration. We assume the vast majority of Fedora and Linux desktop users use what is called 'local' authentication - this means the user account used to allow them to log into their system exists on the system and not in some centrally-managed database. These users will not get any use out of this UI. This is not to say these users would not interact with a remote account to say, get their corporate email. What this means, practically speaking, is that our assumption is that when most Fedora users turn on their system and get a GDM / KDM / XDM login screen in order to access a desktop environment on the system, the username and password they type on that login screen exist locally on that system, not in a centralized database.

Out of the subset of users that will use network-based, centrally-managed authentication systems, it is our assumption that 95% of these users will only need to authenticate to one domain (for example, a university network or a corporate network.) We assume that 5% or less of the set of users that will use centrally-managed authentication to log into their system will need to configure multiple domain authentication.

In summary, our design assumptions for the target of this UI are as follows:

  • Only users who use centrally-managed authentication - 95% of which will only need to worry about one domain.
  • Desktop users - either a desktop workstation or a laptop. We assume laptops will be more common.
  • Users will be physically present in front of the system they are configuring. They won't be configuring another system over the network.
  • Most Fedora users will not need to use this interface.
  • Only root-level users will have access to the interface. This means either power users / self-administered users will use it, or system administrators using the tool to generate configurations to deploy to other systems will use it.

Use-Cases

Case A: Single-Domain

This user uses a single centrally-managed account to log into their system, most likely their place of employment or maybe school (I assume most US schools don't do this though.) They may also have a local account for debugging / troubleshooting or for personal work on the same machine. This configuration will be supported by the UI.

Case B: Multi-Domain

This user may need to log into their machine using two or more accounts that are centrally-managed via two or more systems. For example, if a user is an employee for one corporation and a contractor for another, and has a login to each on the same computer. Extremely rare case. To address this case, the user will not be able to use the UI - instead, they will need to hand-configure this setup in the configuration file. If a user has multiple domains, they will almost never have more than 3 or 4, and 2 is the most common. Sometimes, the user might have domains configured that are not active. They may need a function to set them as active or inactive.

Case C: Local Only

This user only uses the built-in local authentication and account system. They do not need to access a centrally-managed database to log in. This case represents the vast majority of users.

Stories For How Users Will Encounter This UI

Story 1: Fresh Install, Local Only User

  1. User downloads a copy of Fedora from www.fedoraproject.org.
  2. User installs Fedora using the default settings.
  3. User boots machine and encounters firstboot.
  4. User encounters the 'create user' screen of firstboot. He or she is advised that if they need to set up centrally-managed logins, they'll need to click the 'use centrally-managed login' button (We'll avoid the use of the word 'network' since is more vague than 'centrally-managed' for local-only users.)
  5. The user might click on the 'use centrally-managed login' button and get the system-config-auth dialog with two tabs in it, but hopefully will quickly realize it's not meant for them to use and close the dialog, continuing on with firstboot.
  6. The user will log into the desktop without issue.
  7. Ideally, at this point, System > Administration > Authentication will not be available. If it is, the user may open this up through exploration or by accident and encounter the UI there as well.

Story 2: Fresh Install, Single-Domain User

  1. User downloads a copy of Fedora from www.fedoraproject.org.
  2. User installs Fedora using the default settings. They set up a local root account here.
  3. User boots machine and encounters firstboot.
  4. User encounters the 'create user' screen of firstboot. He or she is advised that if they need to set up centrally-managed logins, they'll need to click the 'use centrally-managed login' button (We'll avoid the use of the word 'network' since is more vague than 'centrally-managed' for local-only users.)
  5. User clicks the 'use centrally managed login' button and selects the combination of identity & auth settings they need to based on the technology on their network rather than sssd/legacy split. Depending on the choices the user makes, either sssd will be enabled or the legacy stack will be used.
    • What if the user doesn't know what technology the server uses? They'd be in a bind regardless of the design here - they need this information to be able to set any of this up. We assume it's provided by their helpdesk.
    • The user may be anxious to set up a non-root local account. Should there be a tooltip informing them they may do so later by logging in as root and using System > Administration > Users and Groups??
    • User cannot log in as root to use to System > Administration > Users and Groups to set up a local non-root account - root logins are disabled.
  6. The user finishes firstboot, and attempts to log into their system.
  7. Centrally-managed login works. Yay! All is good.
  8. Centrally-managed login fails. Darn! What went wrong?
    • Is there network access? (does GDM ask this troubleshooting question?)
    • Did the user set something up incorrectly? (does GDM suggest logging in as root and going to the auth ui to fix?)

Discussion

  • This user may be concerned at this point about setting up a local account. They have root already by this time, that's set up in the install program. We could tell the user to log in as root and set up a local account on the command-line, or we could let them create the local account right here (latter is more convenient.) However, that convenience may come at the expense of some convenience for the vast majority of Fedora users.

Story 3: Fresh Install, Multi-Domain User

  1. User downloads a copy of Fedora from www.fedoraproject.org.
  2. User installs Fedora using the default settings. They set up a local root account here.
  3. User boots machine and encounters firstboot.
  4. User encounters the 'create user' screen of firstboot. He or she is advised that if they need to set up centrally-managed logins, they'll need to click the 'use centrally-managed login' button (We'll avoid the use of the word 'network' since is more vague than 'centrally-managed' for local-only users.)
  5. User clicks the 'use centrally managed login' button and selects the combination of identity & auth settings they need to based on the technology on their network rather than sssd/legacy split. Depending on the choices the user makes, either sssd will be enabled or the legacy stack will be used.
  6. The user finishes firstboot, and attempts to log into their system.
  7. Centrally-managed login works. Yay! All is good.
  8. User manually edits configuration files to configure a second domain.

Story 4: Pre-configured Centrally-Managed Desktop

  1. User receives a company-issued desktop with Fedora or RHEL pre-installed on it.
  2. This laptop is pre-configured to log them into the corporate network. They turn it on and attempt to log into their system using credentials provided by their employer.
    • Centrally-managed login works. Yay! All is good.
    • Centrally-managed login fails. Darn! What went wrong?
  3. Let's assume it worked.
  4. User clicks on System > Administration > Authentication (for legacy) or System > Administration > Centrally-Managed Authentication (SSSD ui). Prompted for root password.
    • If they have root, they can see the settings for the first domain only populated in the UI.
    • If they don't have root, they don't open the UI.

What login/authentication methods does SSSD support? What methods are supported by the legacy system?

SSSD

For looking up user accounts on the network, SSSD supports:

  • LDAP servers - meaning RFC2307, OpenLDAP, 389, perhaps SunONE
  • IPA servers - meaning RFC2307bis

Where do POSIX-friendly Active Directory servers go?

NIS will be supported in the future.

For actual authentication, SSSD supports:

  • Kerberos passwords
  • LDAP passwords
  • IPA passwords

Winbind is supported using the legacy stack. Winbind effectively means using Samba to join the machine into an Active Directory domain.

If a user does not want to join the machine but rather use AD as yet another LDAP server and use AD KDC as authentication server she can do it, but for it she would have to get into the sssd configuration manually and set XYZ there.

Legacy System

The legacy system supports non-POSIX Active Directory servers via Winbind, Hesiod servers, NIS, smartcards, and fingerprint readers.

A Note About Offline Authentication

ervers have policies that enforce how often a user may log in while offline without connecting to the authentication server, and can set when that cache expires. Client-side, you can also enable or disable offline login and how old the cache is allowed to get before the user must connect to the server. The server settings, of course, always override what you can set on the client. If the server says your cache will only last 3 days for offline, and you set it to expire after 99 years client-side - the server setting is going to trump the client setting. The client-side enforcement is easily gotten-around by a user with root. It's really not there to prevent a user from logging in to their local machine. Truthfully, it's real purpose is to provide two things, when it's configured correctly (i.e. set up to expire at least somewhat before the server-side enforcement expires).

  1. It will notify the user when they authenticate (by way of a PAM message) that their local credentials are only valid for N more days. This provides the end-user some feedback to know how often they need to check in with the main systems.
  2. If configured as I mentioned before, with the expiration occurring a reasonable amount of time before the server-side lockout, it provides users the ability to recover their credentials without having to contact the helpdesk and have the account unlocked. They just come into the office or attach to the VPN by other means and perform an online login. This has the dual effect, then, of refreshing their local credentials as well as resetting the timeout for the server-side enforcement.

These policies are meant mainly to require users to 'phone home' frequently enough to stay in compliance with account policies - for example, so the user will hit forced password changes. To the user, though, expiration means that until the user can connect to the appropriate network, they are effectively locked out of their account on their machine.

There is a tension here between the central system administrators' need to enforce their policies and the end users' need to be able to log into their system and get work done. Since the server policies trump the client-side policies anyway, I suggest to always set the client to enable offline login, with a cache that has an indefinite lifetime. In situations where this is unacceptable, clients may be deployed with a different default configuration. Also, the server would override the setting anyway.

The way that server-side enforcement of a mandatory connection time works, is that if the system doesn't check in for X days, the server will automatically disable their network credentials. This means that even if the client does come back and try to auth after this time, they will be unable to gain access to network resources until they've called their helpdesk/IT department and had their account unlocked.

A Note About Checking For User Errors

A situation that could have an extremely negative impact on the user experience here is if the user fills out the screen in such a manner that they lock themselves out of being able to log into their computer. When the users are locked out, and sitting at GDM trying to log in, we can't really know why exactly they are unable to log in (they could honestly be mistyping their password, or they could have goofed up the url for their LDAP server.)

We want to try to minimize the chances the users end up in that locked-out scenario. I've added little icons / messages throughout these mockups here to suggest that preventing user error up front, by checking to see that entered URLs are valid at the time they are entered, before the user is locked. It is understood that in some cases the ability to check for these things is not possible, not reliably possible, or would require effort well beyond the scope of the changes being made to the dialog now. That's completely cool. I think it is good food for thought though, to consider whether or not this is a good mechanism to minimize our users' chances of getting locked out of their own machine.

One note about these little checks - if some of the resources the user inputs are on a VPN, as Stephen Gallagher pointed out, the user is unable to connect to VPN during firstboot when this dialog first appears, so a valid URL on a VPN network you're not connected to will indeed fail. To account for that case the messages could use language to reflect, 'we can't contact this resource now' or some other solution could be worked out. So please consider this aspect of the mockups a suggestion that could definitely be improved upon.


Current UI

Here is a gallery of the current system-config-authentication UI from Fedora 12, taken 09 February 2010. Note that this UI is quite old, but the 'SSSD settings' tab was added recently as part of the first phase to integrate SSSD into Fedora 12.