Le plugin geOrchestra réalise quelques adaptation de GéoContrib pour son intégration dans un environnement geOrchestra :
- exploiter l'authentification de l'utilisateur. Le plugin exploite les en-têtes HTTP insérées par le proxy/CAS de geOrchestra après l'authentification de l'utilisateur ;
- mettre à jour la base de données des utilisateurs de GéoContrib à partir de l'annuaire LDAP de geOrchestra, avec une attribution des droits par défaut. La gestion des droits des utilisateurs est toujours réalisée dans l'interface de GéoContrib. Cette mise à jour de la base des utilisateurs est appelée "synchronisation" dans le reste du présent document ;
- désactiver les fonctions d'authentification native de GéoContrib.
L'identification de l'utilisateur connecté à geOrchestra est réalisé en exploitant les en-têtes HTTP tel que décrit dans la documentation de geOrchestra : https://github.com/georchestra/georchestra/tree/20.0.x/security-proxy#headers.
La synchronisation des utilisateurs peut être lancée de 2 manières :
- dans l'interface d'administration de GéoContrib dans la partie "Utilisateurs", un bouton "Synchroniser les utilisateurs" est présent en haut de la page. Ce bouton lance immédiatement la synchronisation des utilisateurs ;
- via une commande Django incluse dans le fichier manage.py. Pour la lancer :
python manage.py georchestra_user_sync
. Cette commande peut être automatisée pour être exécutée périodiquement (via crontab par exemple).
Les informations associées aux utilisateurs et récupérées de l'annuaire LDAP :
- prénom :
givenName
; - nom de famille :
sn
; - nom d'utilisateur/identifiant unique :
uid
; - adresse électronique :
mail
; - appartenance à des groupes d'utilisateurs / rôles de georchestra :
memberOf
.
Certains utilisateurs de l'annuaire ne sont pas importés lors de la synchronisation :
- utilisateurs dont le nom/identifiant unique est présent dans
EXCLUDED_USER_NAMES
; - utilisateurs appartenant à des groupes présents dans
EXCLUDED_USER_GROUPS
; - si
EXCLUSIVE_USER_GROUPS
est défini, tous les utilisateurs n'appartenant à aucun groupe présent dansEXCLUSIVE_USER_GROUPS
.
Certains utilisateurs sont supprimés lors de la synchronisation :
- utilisateurs déjà présents dans GéoContrib et qui ne sont pas importés lors de la synchronisation pour les raisons évoquées précédemment ;
- utilisateurs déjà présents dans GéoContrib mais ne figurant pas dans l'annuaire LDAP.
Néanmoins, les utilisateurs figurant dans PROTECTED_USER_NAMES
ne sont jamais supprimés par la synchronisation. Ils
peuvent l'être manuellement via l'interface d'administration de GéoContrib.
Certains utilisateurs se voient automatiquement attribuer des droits de super utilisateur dans GéoContrib lors de la
synchronisation : ceux figurant dans au moins un groupe d'utilisateurs présent dans ADMIN_USER_GROUPS
.
Certains utilisateurs se voient automatiquement attribuer des droits sur les projets de GéoContrib lors de la synchronisation :
- les utilisateurs appartenant aux groupes paramétrés dans le champ "Groupes LDAP des contributeurs et modérateurs" du projet (cf. interface d'administration Django de GéoContrib dans le formulaire du projet) recoivent automatiquement le rôle de contributeur pour le projet. Néanmoins un utilisateur ayant déjà le rôle de modérateur reste modérateur.
- les utilisateurs appartenant aux groupes paramétrés dans le champ "Groupes LDAP des administrateurs" du projet (cf. interface d'administration Django de GéoContrib dans le formulaire du projet) recoivent automatiquement le rôle d'administrateur du projet.
- les utilisateurs qui ne font pas partis des groupes LDAP mentionnés dans l'interface d'admin, et auxquels des rôles ont été attribués depuis l'onglet "Membres" d'un projet, conservent bien leurs rôles après une synchronisation.
Les exemples de paramètres adaptés au plugin geOrchestra sont présents dans le fichier 'docker/geocontrib/geocontrib.env'.
Le plugin geOrchestra est installé avec GéoContrib. Il suffit de configurer les paramètres dans les settings de GéoContrib ou via des variables d'environnements (voir ci-dessous).
- SSO_PLUGIN : nom du plugin activé. Valeur par défaut : aucune. Pour activer ce plugin :
plugin_georchestra
- SSO_MIDDLEWARE : identification du middleware utilisé pour l'authentification. Valeur par défaut : aucune. Pour
activer ce plugin :
plugin_georchestra.auth.middleware.RemoteUserMiddleware
- HEADER_UID : nom de l'en-tête HTTP identifiant l'utilisateur. Valeur par défaut :
HTTP_SEC_USERNAME
- IGNORED_PATHS : liste des routes ignorées. Valeur par défaut :
geocontrib:logout,
Typiquement :
SSO_PLUGIN=plugin_georchestra
SSO_MIDDLEWARE=plugin_georchestra.auth.middleware.RemoteUserMiddleware
HEADER_UID=HTTP_SEC_USERNAME
IGNORED_PATHS=geocontrib:logout,
- LDAP_URI : adresse du serveur LDAP. Valeur par défaut : Aucune.
- LDAP_USERDN : paramètre user utilisé par l'objet Connection du module ldap3. Valeur par défaut : Aucune.
- LDAP_PASSWD : mot de passe. Valeur par défaut : Aucune.
- LDAP_SEARCH_BASE : préfiltre sur un groupe d'utilisateurs. Exemple (pour éviter d'avoir les utilisateurs dont le
compte est en attente de modération) :
ou=users,dc=georchestra,dc=org
.Valeur par défaut :dc=georchestra,dc=org
. - LDAP_SEARCH_FILTER : filtre appliqué au contenu du LDAP. Valeur par défaut :
(objectClass=person)
Typiquement :
LDAP_URI = ldap://ldap
LDAP_USERDN = cn=admin,dc=georchestra,dc=org
LDAP_PASSWD = secret
LDAP_SEARCH_BASE = ou=users,dc=georchestra,dc=org
LDAP_SEARCH_FILTER = (objectClass=person)
- PROTECTED_USER_NAMES : liste de noms d'utilisateurs (leur identifiant unique) à ne pas supprimer lors de la
synchronisation des utilisateurs (liste de valeurs séparées par des virgules). Exemple :
admin,super_admin
. Valeur par défaut : aucune (chaîne vide). - EXCLUDED_USER_NAMES : liste des noms d'utilisateurs à ne pas importer dans GéoContrib lors de la synchronisation
(liste de valeurs séparées par des virgules). Exemple :
geoserver_privileged_user
. Valeur par défaut : aucune (chaîne vide).
- ADMIN_USER_GROUPS : liste des groupes d'utilisateurs à considérer comme des administrateurs (liste de valeurs
séparées par des points-virgules). Les membres de ces groupes qui sont importés par la synchronisation récupèrent
automatiquement les privilèges suivants : équipe, administrateur et super-utilisateur. Ils acquièrent donc tous les
droits d'administration via l'interface d'administration de l'application. Chacun des groupes d'utilisateurs est défini
à l'aide d'un filtre LDAP appliqué sur le champ
membreOf
des utilisateurs. Exemple :cn=SUPERUSER,ou=roles,dc=georchestra,dc=org;cn=ADMINISTRATOR,ou=roles,dc=georchestra,dc=org;cn=GEOCONTRIB_ADMIN,ou=roles,dc=georchestra,dc=org
. Valeur par défaut :cn=SUPERUSER,ou=roles,dc=georchestra,dc=org;cn=ADMINISTRATOR,ou=roles,dc=georchestra,dc=org
. - EXCLUSIVE_USER_GROUPS : liste des groupes d'utilisateurs auxquels les utilisateurs doivent appartenir pour être
importés dans GéoContrib (liste de valeurs séparées par des points-virgules). Seuls les membres de ces groupes sont
importés (même s'ils font partie des groupes identifiés dans ADMIN_USER_GROUPS). Chacun des groupes d'utilisateurs est
défini à l'aide d'un filtre LDAP appliqué sur le champ
membreOf
des utilisateurs. Exemple :cn=SUPERUSER,ou=roles,dc=georchestra,dc=org;cn=ADMINISTRATOR,ou=roles,dc=georchestra,dc=org;cn=GEOCONTRIB_USER,ou=roles,dc=georchestra,dc=org
. Valeur par défaut : aucune (chaîne vide). - EXCLUDED_USER_GROUPS : liste des groupes d'utilisateurs à ne pas importer dans GéoContrib (liste de valeurs séparées
par des points-virgules). Cela concerne typiquement les utilisateurs dont les comptes sont en attente de modératio.
Chacun des groupes d'utilisateurs est défini à l'aide d'un filtre LDAP appliqué sur le champ
membreOf
des utilisateurs. Exemple :cn=pendingorg,ou=pendingorgs,dc=georchestra,dc=org
. Valeur par défaut : aucune (chaîne vide).
Deux méthodes :
- Utiliser LDAP_SEARCH_BASE avec la valeur
ou=users,dc=georchestra,dc=org
; - Utiliser EXCLUDED_USER_GROUPS en y insérant le groupe
cn=pendingorg,ou=pendingorgs,dc=georchestra,dc=org
.
Pour vérifier les utilisateurs présents :
# Lancer la commande Python
python manage.py shell
# Importer les outils
from geocontrib.models import User
# Vérifier la présence d’un utilisateur en particulier
User.objects.filter(username='cblanchon')
# Compter le nombre d’utilisateurs
User.objects.count()