Starting point: The authentication system for Seafile is LDAP (email/password), which is also used for managing user and groups, etc. We also have an internal SSO service to avoid re-entering credentials (email/password) (Note: using email as a login is not common in our internal process). Everything works fine in version < 11 users can authenticate via LDAP and/or SSO.
After upgrading to version > 11, I ran into several configuration issues:
Following the upgrade notes: Upgrade Notes for 11.0.x mentions migrate_ldapusers.py ā¦
done. Itās possible to log in using SSO and LDAP (login and email) ā¦ works fine.
But the system continues to evolve, and new users are added to LDAP. Now the issue is, it creates two virtual IDs for the same user in SSO and LDAP.
The method of linking accounts via the user profile doesnāt seem feasible to me:
Technically, I donāt see any option to link the LDAP account to the SSO account. Thereās nothing available, whether for LDAP or SSO (same email).
From an IT support perspective, itās impossible to apply this procedure to all our users. Itās way too tedious to document, and it would result in a flood of support requests due to user confusion.
The second method, where no user action is needed, seems more doable at our scaleā¦ but Iām still not convinced!
If I understand correctly, the user still needs to log in via LDAP the first time. Their group memberships are only linked to the virtual ID from the LDAP provider. I could reduce the LDAP sync interval to 4 minutes with the option (LDAP_SYNC_INTERVAL = 4) in seahub_settings.py.
Iām running this SQL query ( ~10minutes):
UPDATE social_auth_usersocialauth sso
JOIN social_auth_usersocialauth ldap
ON sso.uid = ldap.uid
SET sso.username = ldap.username
WHERE sso.provider = 'lab-xxxx.fr'
AND ldap.provider = 'ldap';
itās ok ?
I run this script every 10 minutes, but I canāt predict when a user will use either login method for Seafile.
There arenāt many new users, but Seafile is used inconsistently (some inactive users). The number of licenses might block Seafile usage if there are too many duplicate accounts and licenses.
I find the new authentication process problematic. Is there another method, or maybe I didnāt fully understand? Any ideas? For example, is it possible to have an option where if the UID already exists, it doesnāt create a new virtual ID, and the link is made automatically?
You need a script that check all LDAP entries in social_auth_usersocialauth and add a new entry with provider as ālab-xxxx.frā if not exists.
Your suggestion is inspiring. Maybe we can add an option to check existing LDAP entries before creating a new account when a user login via SSO. What SSO protocol do you use, SAML or OAuth?
#sql
INSERT INTO social_auth_usersocialauth (username, provider, uid, extra_data)
SELECT ldap.username, 'sso.fr' ,ldap.uid, ldap.extra_data
FROM social_auth_usersocialauth ldap
LEFT JOIN social_auth_usersocialauth sso
ON ldap.uid = sso.uid AND sso.provider = 'sso.fr'
WHERE ldap.provider = 'ldap'
AND sso.uid IS NULL;
Hi, do you think the option could be added in a minor release of version 11?
Iām hesitant to upgrade to version 11 (pro) right now, as I might end up with a lot of user tickets to handle. Or will it only be available in the next major release, or not at all?
A new option SSO_LDAP_USE_SAME_UID is added. When it is set to True, when a user login via SSO (including OAuth and SAML2), Seafile will try to find the user with the same ID from LDAP.