Authentification externe par une base MySql

All contributions published for previous SPIP versions

Permettre de gérer les utilisateurs d’un site SPIP depuis un autre système fonctionnant avec une Base de Données MySql

Objectif

Permettre de gérer les utilisateurs d’un site SPIP depuis un autre système fonctionnant avec une Base de Données MySql.

Principe

Ce module s’inspire du fonctionnement de l’authentification habituel de SPIP. Compte-tenu de la grande variété des système de base de données et des systèmes de gestion de comptes utilisateurs, il est impossible de définir un fonctionnement général et/ou universel sans préciser quelques paramètres. Par conséquent, il est livré avec une interface de configuration.

Les modifications du noyau sont minimes, jugez-en vous-même :

Installation

Fichiers à modifier :

-  spip_cookie.php3

Sous les lignes:

// Essayer differentes methodes d'authentification
$auths = array('spip');
if ($ldap_present) $auths[] = 'ldap';

Ajouter la ligne:

if ($bddext_present) $auths[] = 'bddext';

-  inc_login.php3

Remplacer la ligne :

$flag_autres_sources = $GLOBALS['ldap_present'];

Par la ligne :

$flag_autres_sources = $GLOBALS['ldap_present'] || $GLOBALS['bddext_present'];

dans ecrire/

-  install.php3

Remplacer les lignes :

if ($flag_ldap AND !$ldap_present) {
        echo "<div style='border: 1px solid #404040; padding: 10px; text-align: left;'>";
        echo "<b>"._T('info_authentification_externe')."</b>";
        echo "<p>"._T('texte_annuaire_ldap_1');
        echo "<FORM ACTION='install.php3' METHOD='post'>";
        echo "<INPUT TYPE='hidden' NAME='etape' VALUE='ldap1'>";
        echo "<DIV align='$spip_lang_right'><INPUT TYPE='submit' CLASS='fondl' NAME='Valider' VALUE=\""._T('bouton_acces_ldap')."\">";
        echo "</FORM>";
}

Par les lignes :

if ($flag_ldap AND !$ldap_present) {
	echo "<div style='border: 1px solid #404040; padding: 10px; text-align: left;'>";
	echo "<b>"._T('info_authentification_externe')."</b>";
	echo "<p>"._T('texte_annuaire_ldap_1');
	echo "<FORM ACTION='install.php3' METHOD='post'>";
	echo "<INPUT TYPE='hidden' NAME='etape' VALUE='ldap1'>";
	echo "<DIV align='$spip_lang_right'><INPUT TYPE='submit' CLASS='fondl' NAME='Valider' VALUE=\""._T('bouton_acces_ldap')."\"></DIV>";
	echo "</FORM>";
	echo "</DIV>";
	echo "<p>";
}

if (!$bddext_present) {
	echo "<div style='border: 1px solid #404040; padding: 10px; text-align: left;'>";
	echo "<b>"._T('info_authentification_externe')."</b>";
	echo "<p>"._T('bddext:texte_annuaire_1');
	echo "<FORM ACTION='install_bddext.php3' METHOD='post'>";
	echo "<INPUT TYPE='hidden' NAME='etape' VALUE='bddext1'>";
	echo "<DIV align='$spip_lang_right'><INPUT TYPE='submit' CLASS='fondl' NAME='Valider' VALUE=\""._T('bddext:bouton_acces')."\"></DIV>";
	echo "</FORM>";
	echo "</DIV>";
	echo "<p>";
}

-  mes_options.php3

Modifier ou créer le fichier ecrire/mes_options.php3 en ajoutant la ligne :

$mysql_rappel_connexion = true;

fichiers à ajouter (contenus dans le document joint):

module bddext

ecrire/

-  inc_auth_bddext.php3
-  inc_defaut_bddext.php3
-  install_bddext.php3

ecrire/lang/

-  bddext_fr.php3

Configuration

-  Prise en charge de l’option

Un bloc supplémentaire apparaît dans l’étape 5 de l’installation de SPIP :

Prise en charge de l'option
Prise en charge de l’option
5ième étape de l’installation normale de SPIP

Cliquez sur le bouton Accès à MySQL

-  Etape 1 : Configuration des accès à la base de données

Configuration de la base de données
Configuration de la base de données
1ère étape de la configuration du module

La liste déroulante propose un choix qui entrainera la sélection d’élément par défaut.

-  Etape 2 : Validation ou Erreur de l’étape précédente

Validez cette étape ou bien retournez en arrière pour effectuer les corrections éventuelles

-  Etape 3 : Choix de la base et du préfixe éventuel des tables

Configuration de la BDD (2)
Configuration de la BDD (2)
3ième étape de la configuration du module

La saisie d’un préfixe permet de réduire le choix de tables de l’étape suivante. Si vous n’êtes pas sur, vider le champ.

-  Etape 4 : Sélection de la table des utilisateurs, de leur statut par défaut et du mode de cryptage du mot de passe

Paramétrage de la table utilisateurs et statut
Paramétrage de la table utilisateurs et statut
4ième étape de la configuration du module

-  Etape 4bis : Mise en relation des champs spip/système externe

Mise en relation des champs
Mise en relation des champs
avant dernière étape de la configuration du module

-  Etape 5 : Validation avant de revenir à la dernière étape ’normale’

Valider cette étape.


Version pour SPIP 1.8.1 :

  • le zip :
    module bddext pour SPIP1.8.1
  • le contenu du fichier .patch contient les modifs à effectuer sur spip_cookie.php3 et ecrire/install.php3
  • Merci à Joe “Ultron” ACHIM ed Net-Passions.Org pour sa patience et ses tests

Important

Cette mise à jour est faite pour dépanner les utilisateurs de cette contribution souhaitant migrer leur site vers une version spip 1.8.1

Les développements pourraient reprendre, mais sur une autre base de fonctionnement.

updated on 25 February 2007

Discussion

5 discussions

  • didougrenade

    Bonjour j’aimerai savoir s’il existe un moyen sous spip 2.0.6 pour qu’un visiteur se connecte à une page avec un mot de passe et un login contenus dans une base de données mysql. merci d’avance

    Reply to this message

  • 2

    Bonjour,
    Je voudrais mettre en place un site avec ce système d’authentification, j’ai essayé la contrib avec la version 1.8.2 et j’obtient l’erreur suivante:

    Fatal error: Cannot redeclare spip_connect_bddext() (previously declared in D:\www\site\ecrire\inc_connect.php3:8) in D:\www\site\ecrire\inc_connect.php3 on line 11

    J’ai fouillé en long en large les fichiers de spip (je débute sous spip), j’ai essayé de faires quelques modifs, mais à chaque fois ça déplace le problème.

    Celà vient (je pense) du faite que dans la v1.8.2 il n’y a pas le fichier inc_login.php3 et que du coup je n’ai pas pu remplacer la ligne indiqué. J’ai cherché si cette ligne était tout ou en partie présente ailleurs, je n’ai rien trouvé...

    Une idée ? Sinon je prendrais la version précédente...

    Merci !

    • Salut,

      Je propose un zip pour spip 1.8.1 en bas de la contrib. S’il ne fonctionne pas sur spip1.8.2 cela veut dire que cette contrib est obsolète. Comme précisé, je ne la maintiens plus tel quel. Et si je reprends le développement de ce genre de fonctionalité un jour, se sera autrement.

      Désolé.

    • Bonjour,

      Merci, de votre réponse.

      J’avais pris note que la manipulation pouvait ne pas fonctionner avec une version ultérieure, j’ai simplement posé la question au cas où quelqu’un s’était penché sur le problème avec la dernière version.

      J’ai retenté ma chance avec la version 1.8.1 téléchargée sur le site de spip: je ne trouve pas non plus le fichier inc_login.php3 !

      Bon, j’ai réalisé la manipulation sans ce fichier, et on obtient la même erreur.
      Pour résoudre cette erreur (ne fonctionne pas completement avec la version 1.8.2):

      Un fois spip installé avec la manipulation ici présente créez le fichier bddext.php3 (avec les balises php biensûr)

      Copier le bloc suivant qui est présent dans inc_connect.php3 dans le nouveau fichier.

      function spip_connect_bddext()
      $GLOBALS[’bddext_link’] = @mysql_connect(“serveur”,“nom”,“pass”);
      @mysql_select_db(“bdd”);
      return $GLOBALS[’bddext_link’];

      Ajoutez à la fin de votre fichier bddext.php3 la ligne suivante:

      $GLOBALS[’bddext_ok’] = true;

      Puis remplacez le bloc précédent dans inc_connect.php3 par

      if (!$GLOBALS[’bddext_ok’])

      include(’bbdext.php3’);

      Dans la version 1.8.2 malheureusement l’authentification externe ne fonctionne pas, je n’ai pas encore trouvé pourquoi.

      Désolé pour la mise en page, j’ai pas encore compris les raccourcis typographiques de spip... Donc n’oubliez pas qu’il y a quelques accolades qui sont manquantes !

    Reply to this message

  • 2

    Bonjour,

    y aurait-il une procédure particulière pour SPIP 1.9 car je n’arrive pas à faire fonctionner cette liaison entre les tables de PHPBB et SPIP.

    Bien cordialement

    • y a peut-être un plugin qui marche sur la zone, j’ai pas regardé.

      Sinon, faut que je rajoute ça à ma todo :/

      Le mieux est d’en causer sur la liste spip-zone.

    • Coyote

      je cherche également une version compatible 1.9.2...

    Reply to this message

  • J’ai testé cette contribution et elle fonctionne bien merci.

    Pour pouvoir pousser les choses plus loin, j’aurai vuolu savoir par quel moyen SPIP est capable de matcher les utilisateurs SPIP et les utilisateurs PHP-BB.

    Je voudrais être sûre d’avoir bien tout compris aussi :

    le login+nom, l’adresse du site, et l’adresse email sont importés mais non modifiés par la suite, alors que le mot de passe est géré par PHP-BB. C’est ça?

    Merci d’avance!

    Reply to this message

  • 1

    bonjour,

    testé ce MOD, ça fonctionne bien.

    En revanche est-il possible carrément d’utiliser aussi une sorte de “login automatique” lorsqu’on est identifié sous phpBB ?? c’est à dire que si on est déjà identifié via phpBB, peut on s’arranger pour que l’accès à spip/ecrire soit automatique sans passer par la phase resaisie du login/mdp ??

    merci.

    • Pour cela, il faut étudier les cookies spip_session de spip concernant le répertoire ecrire et phpbb_data/phpbb_sid pour le forum phpbb.

      bidouiller le code de vérification de session de spip, mais sans doute aussi celui de phpbb histoire que ça marche dans les deux sens.

      Voilà, bon courage ;-)

    Reply to this message

Comment on this article

Who are you?
  • [Log in]

To show your avatar with your message, register it first on gravatar.com (free et painless) and don’t forget to indicate your Email addresse here.

Enter your comment here

This form accepts SPIP shortcuts {{bold}} {italic} -*list [text->url] <quote> <code> and HTML code <q> <del> <ins>. To create paragraphs, just leave empty lines.

Add a document

Follow the comments: RSS 2.0 | Atom