SPIP - Contrib

[ar] [en] [es] [fr] [it]



Accueil du site > Auteurs et Authentification > Authentification > Archives Authentification

Authentification externe par une base MySql

lundi 15 septembre 2003, par James. Dernier ajout dimanche 25 février 2007


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 :

- inc_login.php3

Remplacer la ligne :

$flag_autres_sources = $GLOBALS['ldap_present'];

Par la ligne :

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 :

- mes_options.php3

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

fichiers à ajouter (contenus dans le document joint) :

Zip - 6.9 ko
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 :

GIF - 4.6 ko
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

GIF - 30.2 ko
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

GIF - 14.1 ko
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

GIF - 20.3 ko
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

GIF - 17.2 ko
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 :
    Zip - 10.8 ko
    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.


Répondre à cet article

  • Procédure particulière pour SPIP 1.9 ?

    30 septembre 2006 12:55, par Bionet

    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

    Répondre à ce message

    Retour au début des forums

  • Authentification externe par une base MySql

    3 décembre 2005 00:48, par bobjol

    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 !

    Répondre à ce message

    • Authentification externe par une base MySql 3 décembre 2005 13:18, par James

      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é.

      Répondre à ce message

      • Authentification externe par une base MySql 3 décembre 2005 23:34, par bobjol

        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 !

        Répondre à ce message

    Retour au début des forums

  • > Authentification externe par une base MySql

    10 août 2005 15:54, par Miss Mopi

    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 !

    Répondre à ce message

    Retour au début des forums

  • > Authentification externe par une base MySql

    9 octobre 2004 12:53, par smrhp

    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.

    Répondre à ce message

    • > Authentification externe par une base MySql 9 octobre 2004 13:31, par James

      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 ;-)

      Répondre à ce message

    Retour au début des forums



Suivre la vie du site RSS 2.0 | Plan du site | Espace privé | Charte et vie SPIP-Contrib | SPIP | L'autre.net