Bonjour,
Je viens d'installer la dernière version de Piwigo (2.7.4) sur mon serveur perso (Linux Debian Wheezy) et souhaitant implémenter l’authentification des utilisateur via mon annuaire LDAP, je me suis endu compte que l'unique plugin pour interfacer PWG avec LDAP n'était plus supporté par son auteur, et incompatible avec la branche actuelle de Piwigo !
J'ai donc commencé à discuter avec l'auteur pour porter son plugin vers la branche 2.7 et ce dernier semble prêt à m'aider, mais partant de zéro sur le dev de PWG, et mon php etant passablement rouillé, je souhaiterais avoir quelques explications sur l'authentification dans Piwigo. J'ai parcouru la documentation en ligne, qui est assez lacunaire, et (me semble-t-il) complètement obsolète.
Je suis donc preneur de toute information utile pour porter ce plugin vers la branche 2.7 de PWG
Merci,
Rico
Hors ligne
la doc technique est à jour en anglais
http://piwigo.org/doc/doku.php?id=dev:e … ns:plugins
pour ajouter une méthode d'authentification à Piwigo il faut utiliser le trigger try_log_user
voir http://piwigo.org/dev/browser/trunk/inc … .php#L1076 pour l'implémentation par défaut
add_event_handler('try_log_user', 'try_log_ldap', EVENT_PRIORITY_NEUTRAL-40); function try_log_ldap($success, $username, $password, $remember_me) { if ($success===true) { return true; } if (/* login ldap success */) // <= logique LDAP ici { log_user($user_id, $remember_me); trigger_notify('login_success', stripslashes($username)); return true; } trigger_notify('login_failure', stripslashes($username)); return false; }
les méthodes de login se font les unes après les autres jusqu’à ce que l'une d'entre elles renvoie true
EVENT_PRIORITY_NEUTRAL-40 permet de passer avant le login par défaut
donc si vous voulez désactiver totalement le login normal vous pouvez renvoyer true même en cas d'échec (à vous de gérer les messages d'erreur dans ce cas)
voir par exemple Social Connect qui bloque la méthode classique si le nom d'utilisateur correspond à un utilisateur OAuth
[Github] Piwigo-Social-Connect file include/public_events.inc.php@L22
Hors ligne
Bon, j'ai déjà identifié le probléme qui empêche le plugin de fonctionner correctement avec la branche 2.7 : la méthode "trigger_action" n'est visiblement plus utilisée... le simple fait de commenter les 4 appels à cette fonction dans main.inc.php suffit à rendre le plugin à nouveau fonctionnel !
Reste à voir ce que faisait cette fonction(logging ?), et par quoi la remplacer...
Hors ligne
Hors ligne