Configure LDAP authentication in Nextcloud with FreeIPA
First I like to create a system user in FreeIPA and add it to the system users group and give it a password. This will allow Nextcloud to browse the directory to get a list of users and groups.
Then, after activating the user-ldap plugin, go to the administration page and find the LDAP section. The LDAP configuration is done by sequentially filling form fields in six tabs: Server, Users, Login Attributes, Groups, Advanced and Experts.
By the way, I don’t mind showing the world my IPA domain and the hostname because none of that is directly exposed to the Internet and I don’t believe in security through obscurity.
Server
Since the communication between my Nextcloud and FreeIPA servers are
done on a trusted network, I don’t use LDAP over SSL, and I don’t
specify the ldaps://
prefix, just the hostname and the 389
port. The
bind DN looks something like this:
uid=nextcloud,cn=users,cn=accounts,dc=private,dc=deverteuil,dc=net
…and the base DN is your FreeIPA domain in LDIF format:
dc=private,dc=deverteuil,dc=net
data:image/s3,"s3://crabby-images/9c393/9c3939d4e98216af1c121d2a915463606ac1a779" alt="screenshot of the Server tab"
Users
Just select “Only these object classes: posixAccount
”.
data:image/s3,"s3://crabby-images/5f413/5f41330872804c69c6fd1e280086e6582c75ec9f" alt="screenshot of the Users tab"
Login Attributes
For the section “[…] find the user based on the following attributes:”, check “LDAP / AD Username”.
data:image/s3,"s3://crabby-images/0ade9/0ade9565307d5036ce676213b909981de3900601" alt="screenshot of the Login Attributes tab"
Groups
I suggest you create a usergroup in FreeIPA called “nextcloud_users” and add the users authorized to login to Nextcloud to it.
Select “Only these object classes: ipausergroup
” and “Only from these
groups: nextcloud_users
”.
data:image/s3,"s3://crabby-images/411a9/411a91e9274293e7104aab04d07d1812f888fcfc" alt="screenshot of the Groups tab"
Advanced
Fill in the following field in the Directory Settings section:
- User Display Name Field:
displayname
- Base User Tree:
cn=users,cn=accounts,dc=example,dc=com
- Group Display Name Field:
cn
- Base Group Tree:
cn=groups,cn=accounts,dc=example,dc=com
Of course, replace dc=example,dc=com
with your own base DN.
data:image/s3,"s3://crabby-images/8df42/8df42d736f7164e9cf953ad9b88f1b55c0299be4" alt="screenshot of the Advanced tab, Directory Settings section"
In the Special Attributes section, fill in these:
- Email Field:
mail
- User Home Folder Naming Rule:
uid
data:image/s3,"s3://crabby-images/282db/282db9f3c12ddba62f31a6f0476ffa7a478df519" alt="screenshot of the Advanced tab, Special Attributes section"
Expert
- UUID Attribute for Users:
ipaUniqueID
- UUID Attribute for Groups:
ipaUniqueID
data:image/s3,"s3://crabby-images/70058/700584bb2a83bbc6be0cff1a7b4680f3fef15781" alt="screenshot of the Expert tab"
References
I used Apache Directory Studio to learn the LDAP schema on my FreeIPA server.
This reference was a good start but not quite complete: [Owncloud Authentication against FreeIPA](https://www.freeipa.org/page/Owncloud_Authentication_against_Fr eeIPA)
Software versions
Nextcloud 9.0.51
FreeIPA 4.3.1