website/docs: add freeipa docs (#1666)
* website/docs: add freeipa docs Signed-off-by: M. David Bennett <mdavidbennett@syntheticworks.com> * website/docs: fix freeipa settings screenshot Signed-off-by: M. David Bennett <mdavidbennett@syntheticworks.com>
BIN
website/docs/integrations/sources/freeipa/01_user_create.png
Normal file
After Width: | Height: | Size: 45 KiB |
BIN
website/docs/integrations/sources/freeipa/02_user_roles.png
Normal file
After Width: | Height: | Size: 27 KiB |
BIN
website/docs/integrations/sources/freeipa/03_add_user_role.png
Normal file
After Width: | Height: | Size: 49 KiB |
After Width: | Height: | Size: 189 KiB |
After Width: | Height: | Size: 234 KiB |
BIN
website/docs/integrations/sources/freeipa/06_sync_source.png
Normal file
After Width: | Height: | Size: 122 KiB |
BIN
website/docs/integrations/sources/freeipa/07_password_stage.png
Normal file
After Width: | Height: | Size: 125 KiB |
73
website/docs/integrations/sources/freeipa/index.md
Normal file
|
@ -0,0 +1,73 @@
|
||||||
|
---
|
||||||
|
title: FreeIPA
|
||||||
|
---
|
||||||
|
|
||||||
|
## Preparation
|
||||||
|
|
||||||
|
The following placeholders will be used:
|
||||||
|
|
||||||
|
- `svc_authentik` is the name of the bind account.
|
||||||
|
- `freeipa.company` is the Name of the domain.
|
||||||
|
- `ipa1.freeipa.company` is the Name of the FreeIPA server.
|
||||||
|
|
||||||
|
## FreeIPA Setup
|
||||||
|
|
||||||
|
1. Log into FreeIPA.
|
||||||
|
|
||||||
|
2. Create a user in FreeIPA, matching your naming scheme. Provide a strong password, example generation methods: `pwgen 64 1` or `openssl rand -base64 36`. Once done click `Add and Edit`.
|
||||||
|
|
||||||
|
![](./01_user_create.png)
|
||||||
|
|
||||||
|
3. In the user management screen, select the Roles tab.
|
||||||
|
|
||||||
|
![](./02_user_roles.png)
|
||||||
|
|
||||||
|
4. Add a role that has privileges to change user passwords, the default `User Administrators` role is sufficient. This is needed to support password resets from within authentik.
|
||||||
|
|
||||||
|
![](./03_add_user_role.png)
|
||||||
|
|
||||||
|
5. By default, if an administrator account resets a user's password in FreeIPA the user's password expires after the first use and must be reset again. This is a security feature to ensure password complexity and history policies are enforced. To bypass this feature for a more seamless experience, you can make the following modification on each of your FreeIPA servers:
|
||||||
|
|
||||||
|
```
|
||||||
|
$ ldapmodify -x -D "cn=Directory Manager" -W -h ipa1.freeipa.company -p 389
|
||||||
|
|
||||||
|
dn: cn=ipa_pwd_extop,cn=plugins,cn=config
|
||||||
|
changetype: modify
|
||||||
|
add: passSyncManagersDNs
|
||||||
|
passSyncManagersDNs: uid=svc_authentik,cn=users,cn=accounts,dc=freeipa,dc=company
|
||||||
|
```
|
||||||
|
|
||||||
|
Additional info: [22.1.2. Enabling Password Reset Without Prompting for a Password Change at the Next Login](https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/7/html/linux_domain_identity_authentication_and_policy_guide/user-authentication#user-passwords-no-expiry)
|
||||||
|
|
||||||
|
## authentik Setup
|
||||||
|
In authentik, create a new LDAP Source in Resources -> Sources.
|
||||||
|
|
||||||
|
Use these settings:
|
||||||
|
|
||||||
|
- Server URI: `ldaps://ipa1.freeipa.company`
|
||||||
|
- Bind CN: `uid=svc_authentik,cn=users,cn=accounts,dc=freeipa,dc=company`
|
||||||
|
- Bind Password: The password you've given the user above
|
||||||
|
- Base DN: `dc=freeipa,dc=company`
|
||||||
|
- Property mappings: Control/Command-select all Mappings which start with "authentik default LDAP" and "authentik default OpenLDAP"
|
||||||
|
- Group property mappings: Select "authentik default OpenLDAP Mapping: cn"
|
||||||
|
|
||||||
|
Additional settings:
|
||||||
|
|
||||||
|
- Group: If selected, all synchronized groups will be given this group as a parent.
|
||||||
|
- Addition User/Group DN: `cn=users,cn=accounts`
|
||||||
|
- Addition Group DN: `cn=groups,cn=accounts`
|
||||||
|
- User object filter: `(objectClass=person)`
|
||||||
|
- Group object filter: `(objectClass=groupofnames)`
|
||||||
|
- Group membership field: `member`
|
||||||
|
- Object uniqueness field: `ipaUniqueID`
|
||||||
|
|
||||||
|
![](./04_source_settings_1.png)
|
||||||
|
![](./05_source_settings_2.png)
|
||||||
|
|
||||||
|
After you save the source, you can kick off a synchronization by navigating to the source, clicking on the "Sync" tab, and clicking the "Run sync again" button.
|
||||||
|
|
||||||
|
![](./06_sync_source.png)
|
||||||
|
|
||||||
|
Lastly, verify that the "User database + LDAP password" backend is selected in the "Password Stage" under Flows -> Stages.
|
||||||
|
|
||||||
|
![](./07_password_stage.png)
|
|
@ -9,7 +9,9 @@ Sources allow you to connect authentik to an existing user directory. They can a
|
||||||
This source allows you to import users and groups from an LDAP Server.
|
This source allows you to import users and groups from an LDAP Server.
|
||||||
|
|
||||||
:::info
|
:::info
|
||||||
For Active Directory, follow the [Active Directory Integration](https://goauthentik.io/docs/integrations/sources/active-directory/index)
|
For Active Directory, follow the [Active Directory Integration](integrations/sources/active-directory/index.md)
|
||||||
|
|
||||||
|
For FreeIPA, follow the [FreeIPA Integration](integrations/sources/freeipa/index.md)
|
||||||
:::
|
:::
|
||||||
|
|
||||||
- Server URI: URI to your LDAP server/Domain Controller.
|
- Server URI: URI to your LDAP server/Domain Controller.
|
||||||
|
|
|
@ -74,6 +74,7 @@ module.exports = {
|
||||||
"integrations/sources/apple/index",
|
"integrations/sources/apple/index",
|
||||||
"integrations/sources/active-directory/index",
|
"integrations/sources/active-directory/index",
|
||||||
"integrations/sources/discord/index",
|
"integrations/sources/discord/index",
|
||||||
|
"integrations/sources/freeipa/index",
|
||||||
"integrations/sources/github/index",
|
"integrations/sources/github/index",
|
||||||
"integrations/sources/google/index",
|
"integrations/sources/google/index",
|
||||||
"integrations/sources/ldap/index",
|
"integrations/sources/ldap/index",
|
||||||
|
|