[SPIP][PLUGINS] v3.0-->v3.2
[lhc/web/www.git] / www / ecrire / inc / install.php
index 9ff5e62..ffc2458 100644 (file)
@@ -3,7 +3,7 @@
 /***************************************************************************\
  *  SPIP, Systeme de publication pour l'internet                           *
  *                                                                         *
- *  Copyright (c) 2001-2016                                                *
+ *  Copyright (c) 2001-2017                                                *
  *  Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James  *
  *                                                                         *
  *  Ce programme est un logiciel libre distribue sous licence GNU/GPL.     *
 /**
  * Gestion de l'installation de SPIP
  *
- * @package SPIP\Installation
-**/
+ * @package SPIP\Core\Installation
+ **/
 
-if (!defined('_ECRIRE_INC_VERSION')) return;
+if (!defined('_ECRIRE_INC_VERSION')) {
+       return;
+}
 
 
 /**
@@ -27,23 +29,24 @@ if (!defined('_ECRIRE_INC_VERSION')) return;
  * est chargé.
  *
  * @example
+ *     ```
  *     install_fichier_connexion(_FILE_CONNECT_TMP, $contenu);
- * 
+ *     ```
+ *
  * @todo
  *     Renommer cette fonction qui peut servir à d'autres utilisations ?
- * 
+ *
  * @param string $nom
  *     Chemin du fichier à créer
  * @param string $texte
  *     Code source du fichier (sans l'ouverture/fermeture PHP)
  * @return void
-**/
-function install_fichier_connexion($nom, $texte)
-{
-       $texte = "<"."?php\n"
-       . "if (!defined(\"_ECRIRE_INC_VERSION\")) return;\n"
-       . $texte
-       . "?".">";
+ **/
+function install_fichier_connexion($nom, $texte) {
+       $texte = "<" . "?php\n"
+               . "if (!defined(\"_ECRIRE_INC_VERSION\")) return;\n"
+               . $texte
+               . "?" . ">";
 
        ecrire_fichier($nom, $texte);
 }
@@ -59,65 +62,69 @@ function install_fichier_connexion($nom, $texte)
  * @internal
  *     Attention etape_ldap4 suppose qu'il n'y aura qu'un seul appel de fonction
  *     dans le fichier produit.
- * 
- * @param string $adr       Adresse de la base de données {@example 'localhost'}
- * @param string $port      Numéro de port
- * @param string $login     Login de connexion
- * @param string $pass      Mot de passe de connexion
- * @param string $base      Nom de la base de données
- * @param string $type      Moteur SQL {@example 'sqlite3', 'mysql'}
- * @param string $pref      Préfixe des tables {@example 'spip'}
- * @param string $ldap      ?
+ *
+ * @param string $adr Adresse de la base de données {@example 'localhost'}
+ * @param string $port Numéro de port
+ * @param string $login Login de connexion
+ * @param string $pass Mot de passe de connexion
+ * @param string $base Nom de la base de données
+ * @param string $type Moteur SQL {@example 'sqlite3', 'mysql'}
+ * @param string $pref Préfixe des tables {@example 'spip'}
+ * @param string $ldap Type d'authentification (cas si 'ldap')
+ * @param string $charset Charset de la connexion SQL
  * @return string
  *     Texte du fichier de connexion
- * 
-**/
-function install_connexion($adr, $port, $login, $pass, $base, $type, $pref, $ldap='')
-{
-       $adr = addcslashes($adr,"'\\");
-       $port = addcslashes($port,"'\\");
-       $login = addcslashes($login,"'\\");
-       $pass = addcslashes($pass,"'\\");
-       $base = addcslashes($base,"'\\");
-       $type = addcslashes($type,"'\\");
-       $pref = addcslashes($pref,"'\\");
-       $ldap = addcslashes($ldap,"'\\");
-       return "\$GLOBALS['spip_connect_version'] = 0.7;\n"
+ *
+ **/
+function install_connexion($adr, $port, $login, $pass, $base, $type, $pref, $ldap = '', $charset = '') {
+       $adr = addcslashes($adr, "'\\");
+       $port = addcslashes($port, "'\\");
+       $login = addcslashes($login, "'\\");
+       $pass = addcslashes($pass, "'\\");
+       $base = addcslashes($base, "'\\");
+       $type = addcslashes($type, "'\\");
+       $pref = addcslashes($pref, "'\\");
+       $ldap = addcslashes($ldap, "'\\");
+       $charset = addcslashes($charset, "'\\");
+
+       return "\$GLOBALS['spip_connect_version'] = 0.8;\n"
        . "spip_connect_db("
        . "'$adr','$port','$login','$pass','$base'"
-       . ",'$type', '$pref','$ldap');\n";
+       . ",'$type', '$pref','$ldap','$charset');\n";
 }
 
 
 /**
  * Analyse un fichier de connexion à une base de données
- * 
- * Le fichier contient normalement le resultat de la fonction install_connexion().
- * L'analyse tient également compte des syntaxes des versions precedentes.
- * 
- * @param $string $file
+ *
+ * Le fichier contient normalement le résultat de la fonction install_connexion().
+ * L'analyse tient également compte des syntaxes des versions précédentes.
+ *
+ * @param string $file
  *     Chemin du fichier de connexion à analyser
  * @return array
  *     Tableau des informations sur la connexion
-**/
-function analyse_fichier_connection($file)
-{
+ **/
+function analyse_fichier_connection($file) {
        $s = @join('', file($file));
        if (preg_match("#mysql_connect\([\"'](.*)[\"'],[\"'](.*)[\"'],[\"'](.*)[\"']\)#", $s, $regs)) {
                array_shift($regs);
+
                return $regs;
        } else {
                $ar = '\s*\'([^\']*)\'';
                $r = '\s*,' . $ar;
-               $r = "#spip_connect_db[(]$ar$r$r$r$r(?:$r(?:$r(?:$r)?)?)?#";
+               $r = "#spip_connect_db[(]$ar$r$r$r$r(?:$r(?:$r(?:$r(?:$r)?)?)?)?#";
                if (preg_match($r, $s, $regs)) {
-                       $regs[2] = $regs[1] . (!$regs[2] ? '' : ":$port_db;");
+                       $regs[2] = $regs[1] . (!$regs[2] ? '' : ":" . $regs[2] . ";");
                        array_shift($regs);
                        array_shift($regs);
+
                        return $regs;
                }
        }
        spip_log("$file n'est pas un fichier de connexion");
+
        return array();
 }
 
@@ -125,80 +132,79 @@ function analyse_fichier_connection($file)
  * Liste les connecteurs aux bases SQL disponibles
  *
  * Dans le code SPIP ces connecteurs sont souvent appelés $connect ou $serveur
- * 
+ *
  * @example
  *     $bases = bases_referencees(_FILE_CONNECT_TMP);
- * 
- * @param $string $exclu
+ *
+ * @param string $exclu
  *     Exclure un connecteur particulier (nom du fichier)
  * @return array
  *     Liste des noms de connecteurs
-**/
-function bases_referencees($exclu='')
-{
+ **/
+function bases_referencees($exclu = '') {
        $tables = array();
-       foreach(preg_files(_DIR_CONNECT, '.php$') as $f) {
-               if ($f != $exclu AND analyse_fichier_connection($f))
-                       $tables[]= basename($f, '.php');
+       foreach (preg_files(_DIR_CONNECT, '.php$') as $f) {
+               if ($f != $exclu and analyse_fichier_connection($f)) {
+                       $tables[] = basename($f, '.php');
+               }
        }
+
        return $tables;
 }
 
 
-function install_mode_appel($server_db, $tout=true)
-{
+function install_mode_appel($server_db, $tout = true) {
        return ($server_db != 'mysql') ? ''
-       : (($tout  ? test_rappel_nom_base_mysql($server_db) : '')
-               . test_sql_mode_mysql($server_db)       );
+               : (($tout ? test_rappel_nom_base_mysql($server_db) : '')
+                       . test_sql_mode_mysql($server_db));
 }
 
 //
 // Verifier que l'hebergement est compatible SPIP ... ou l'inverse :-)
 // (sert a l'etape 1 de l'installation)
-// http://doc.spip.org/@tester_compatibilite_hebergement
+// http://code.spip.net/@tester_compatibilite_hebergement
 function tester_compatibilite_hebergement() {
        $err = array();
 
        $p = phpversion();
-       if (preg_match(',^([0-9]+)\.([0-9]+)\.([0-9]+),', $p, $regs)) {
-               $php = array($regs[1], $regs[2], $regs[3]);
-               $m = '5.1.0';
-               $min = explode('.', $m);
-               if ($php[0]<$min[0]
-               OR ($php[0]==$min[0] AND $php[1]<$min[1])
-               OR ($php[0]==$min[0] AND $php[1]==$min[1] AND $php[2]<$min[2]))
-                       $err[] = _T('install_php_version', array('version' => $p,  'minimum' => $m));
+       if (version_compare($p, _PHP_MIN, '<')) {
+               $err[] = _T('install_php_version', array('version' => $p, 'minimum' => _PHP_MIN));
        }
 
        // Si on n'a pas la bonne version de PHP, c'est la fin
-       if ($err) 
-               die("<div class='error'>" 
-               . "<h3>"._T('avis_attention').'</h3><p>'._T('install_echec_annonce')."</p><ul class='spip'>"
-               . "<li><strong>{$err[0]}</strong></li>\n</ul></div>");
+       if ($err) {
+               die("<div class='error'>"
+                       . "<h3>" . _T('avis_attention') . '</h3><p>' . _T('install_echec_annonce') . "</p><ul class='spip'>"
+                       . "<li><strong>{$err[0]}</strong></li>\n</ul></div>");
+       }
 
        // Il faut une base de donnees tout de meme ...
        $serveurs = install_select_serveur();
-       if (!$serveurs)
+       if (!$serveurs) {
                $err[] = _T('install_extension_php_obligatoire')
-               . " <a href='http://www.php.net/mysql'>MYSQL</a>"
-               . "| <a href='http://www.php.net/pgsql'>PostgreSQL</a>"
-               . "| <a href='http://www.php.net/sqlite'>SQLite</a>";
+                       . " <a href='http://www.php.net/mysql'>MYSQL</a>"
+                       . "| <a href='http://www.php.net/pgsql'>PostgreSQL</a>"
+                       . "| <a href='http://www.php.net/sqlite'>SQLite</a>";
+       }
 
        // et il faut preg
-       if (!function_exists('preg_match_all'))
+       if (!function_exists('preg_match_all')) {
                $err[] = _T('install_extension_php_obligatoire')
-               . " <a href='http://se.php.net/pcre'>PCRE</a>";
+                       . " <a href='http://se.php.net/pcre'>PCRE</a>";
+       }
 
        // et surtout pas ce mbstring.overload
-       if ($a = @ini_get('mbstring.func_overload'))
+       if ($a = @ini_get('mbstring.func_overload')) {
                $err[] = _T('install_extension_mbstring')
-               . "mbstring.func_overload=$a - <a href='http://www.php.net/mb_string'>mb_string</a>.<br /><small>";
+                       . "mbstring.func_overload=$a - <a href='http://www.php.net/mb_string'>mb_string</a>.<br /><small>";
+       }
 
        if ($err) {
-                       echo "<div class='error'>"
-                               ."<h3>"._T('avis_attention').'</h3><p>'._T('install_echec_annonce')."</p><ul class='spip'>";
-                       foreach($err as $e)
-                               echo "<li><strong>$e</strong></li>\n";
+               echo "<div class='error'>"
+                       . "<h3>" . _T('avis_attention') . '</h3><p>' . _T('install_echec_annonce') . "</p><ul class='spip'>";
+               foreach ($err as $e) {
+                       echo "<li><strong>$e</strong></li>\n";
+               }
 
                # a priori ici on pourrait die(), mais il faut laisser la possibilite
                # de forcer malgre tout (pour tester, ou si bug de detection)
@@ -207,55 +213,57 @@ function tester_compatibilite_hebergement() {
 }
 
 
-// Une fonction pour faciliter la recherche du login (superflu ?)
-// http://doc.spip.org/@login_hebergeur
+/** 
+ * Faciliter la recherche du login d'installation en fonction de certains hébergeurs connus
+ * 
+ * @note superflu ??
+ */
 function login_hebergeur() {
-       global $HTTP_X_HOST, $REQUEST_URI, $SERVER_NAME, $HTTP_HOST;
-
        $base_hebergeur = 'localhost'; # par defaut
 
-       // Lycos (ex-Multimachin)
-       if ($HTTP_X_HOST == 'membres.lycos.fr') {
-               preg_match(',^/([^/]*),', $REQUEST_URI, $regs);
-               $login_hebergeur = $regs[1];
-       }
-       // Altern
-       else if (preg_match(',altern\.com$,', $SERVER_NAME)) {
-               preg_match(',([^.]*\.[^.]*)$,', $HTTP_HOST, $regs);
-               $login_hebergeur = preg_replace('[^\w\d]', '_', $regs[1]);
-       }
        // Free
-       else if (preg_match(',(.*)\.free\.fr$,', $SERVER_NAME, $regs)) {
+       if (preg_match(',(.*)\.free\.fr$,', $_SERVER['SERVER_NAME'], $regs)) {
                $base_hebergeur = 'sql.free.fr';
                $login_hebergeur = $regs[1];
-       } else $login_hebergeur = '';
+       } else {
+               $login_hebergeur = '';
+       }
 
        return array($base_hebergeur, $login_hebergeur);
 }
 
 
-// http://doc.spip.org/@info_etape
-function info_etape($titre, $complement = ''){
-       return "<h2>".$titre."</h2>\n" .
-       ($complement ? "".$complement."\n":'');
+// http://code.spip.net/@info_etape
+function info_etape($titre, $complement = '') {
+       return "<h2>" . $titre . "</h2>\n" .
+       ($complement ? "" . $complement . "\n" : '');
 }
 
-// http://doc.spip.org/@bouton_suivant
+/**
+ * Retourne le code HTML d'un bouton `suivant>>` pour les phases d'installation
+ *
+ * @param string $code Texte du bouton
+ * @return string Code HTML du bouton
+ **/
 function bouton_suivant($code = '') {
-       if($code=='') $code = _T('bouton_suivant');
+       if ($code == '') {
+               $code = _T('bouton_suivant');
+       }
        static $suivant = 0;
-       $id = 'suivant'.(($suivant>0)?strval($suivant):'');
-       $suivant +=1;
-       return "\n<p class='boutons suivant'><input id='".$id."' type='submit'\nvalue=\"" .
-               $code .
-               " >>\" /></p>\n";
+       $id = 'suivant' . (($suivant > 0) ? strval($suivant) : '');
+       $suivant += 1;
+
+       return "\n<p class='boutons suivant'><input id='" . $id . "' type='submit'\nvalue=\"" .
+       $code .
+       " >>\" /></p>\n";
 }
 
-// http://doc.spip.org/@info_progression_etape
-function info_progression_etape($en_cours,$phase,$dir, $erreur = false){
+// http://code.spip.net/@info_progression_etape
+function info_progression_etape($en_cours, $phase, $dir, $erreur = false) {
        //$en_cours = _request('etape')?_request('etape'):"";
-       $liste = find_all_in_path($dir,$phase.'(([0-9])+|fin)[.]php$');
-       $debut = 1; $etat = "ok";
+       $liste = find_all_in_path($dir, $phase . '(([0-9])+|fin)[.]php$');
+       $debut = 1;
+       $etat = "ok";
        $last = count($liste);
 //     $texte_etat = array('ok'=>'OK','encours'=>_T('en_cours'),'todo'=>_T('todo'));
 
@@ -274,260 +282,279 @@ function info_progression_etape($en_cours,$phase,$dir, $erreur = false){
 
        $aff_etapes = "<ul id='infos_etapes' class='infos_$phase$en_cours'>";
 
-       foreach($liste as $etape=>$fichier){
+       foreach ($liste as $etape => $fichier) {
                if ($debut < $last) {
-                       if ($debut == $en_cours && $erreur) $class = "on erreur";
-                       else if ($debut == $en_cours) $class = "on";
-                       else if ($debut > $en_cours) $class = "prochains";
-                       else $class = "valides";
+                       if ($debut == $en_cours && $erreur) {
+                               $class = "on erreur";
+                       } else {
+                               if ($debut == $en_cours) {
+                                       $class = "on";
+                               } else {
+                                       if ($debut > $en_cours) {
+                                               $class = "prochains";
+                                       } else {
+                                               $class = "valides";
+                                       }
+                               }
+                       }
 
                        $aff_etapes .= "<li class='$class'><div class='fond'>";
-                       $aff_etapes .= ($debut == $en_cours)?"<strong>":'';
-                       $aff_etapes .= "<em>"._T('etape')." </em><span class='numero_etape'>$debut</span><em>&nbsp;: </em>";
+                       $aff_etapes .= ($debut == $en_cours) ? "<strong>" : '';
+                       $aff_etapes .= "<em>" . _T('etape') . " </em><span class='numero_etape'>$debut</span><em>&nbsp;: </em>";
                        $aff_etapes .= $intitule_etat["$phase"][$debut];
-                       $aff_etapes .= ($debut == $en_cours)?"</strong>":'';
+                       $aff_etapes .= ($debut == $en_cours) ? "</strong>" : '';
                        $aff_etapes .= "</div></li>";
                }
                $debut++;
        }
        $aff_etapes .= "</ul>";
        $aff_etapes .= "<br class='nettoyeur' />\n";
+
        return $aff_etapes;
 }
 
 
-// http://doc.spip.org/@fieldset
-function fieldset($legend,  $champs = array(), $apres='', $avant='') {
+// http://code.spip.net/@fieldset
+function fieldset($legend, $champs = array(), $apres = '', $avant = '') {
        return "<fieldset>\n" .
-         $avant .
-         ($legend ? "<legend>".$legend."</legend>\n" : '') .
-         fieldset_champs($champs) .
-         $apres .
-         "</fieldset>\n";
+       $avant .
+       ($legend ? "<legend>" . $legend . "</legend>\n" : '') .
+       fieldset_champs($champs) .
+       $apres .
+       "</fieldset>\n";
 }
 
-function fieldset_champs($champs = array())
-  {
+function fieldset_champs($champs = array()) {
        $fieldset = '';
        foreach ($champs as $nom => $contenu) {
                $type = isset($contenu['hidden']) ? 'hidden' : (preg_match(',^pass,', $nom) ? 'password' : 'text');
                $class = isset($contenu['hidden']) ? '' : "class='formo' size='40' ";
-               if(isset($contenu['alternatives'])) {
-                       $fieldset .= $contenu['label'] ."\n";
-                       foreach($contenu['alternatives'] as $valeur => $label) {
-                               $fieldset .= "<input type='radio' name='".$nom .
-                               "' id='$nom-$valeur' value='$valeur'"
-                                 .(($valeur==$contenu['valeur'])?"\nchecked='checked'":'')
-                                 ."/>\n";
-                               $fieldset .= "<label for='$nom-$valeur'>".$label."</label>\n";
+               if (isset($contenu['alternatives'])) {
+                       $fieldset .= $contenu['label'] . "\n";
+                       foreach ($contenu['alternatives'] as $valeur => $label) {
+                               $fieldset .= "<input type='radio' name='" . $nom .
+                                       "' id='$nom-$valeur' value='$valeur'"
+                                       . (($valeur == $contenu['valeur']) ? "\nchecked='checked'" : '')
+                                       . "/>\n";
+                               $fieldset .= "<label for='$nom-$valeur'>" . $label . "</label>\n";
                        }
                        $fieldset .= "<br />\n";
-               }
-               else {
-                       $fieldset .= "<label for='".$nom."'>".$contenu['label']."</label>\n";
-                       $fieldset .= "<input ".$class."type='".$type."' id='" . $nom . "' name='".$nom."'\nvalue='".$contenu['valeur']."'"
-                                                         .(preg_match(',^(pass|login),', $nom)?" autocomplete='off'":'')
-                                 . ((isset($contenu['required']) AND $contenu['required'])?" required='required'":"")
-                                 .     " />\n";
+               } else {
+                       $fieldset .= "<label for='" . $nom . "'>" . $contenu['label'] . "</label>\n";
+                       $fieldset .= "<input " . $class . "type='" . $type . "' id='" . $nom . "' name='" . $nom . "'\nvalue='" . $contenu['valeur'] . "'"
+                               . (preg_match(',^(pass|login),', $nom) ? " autocomplete='off'" : '')
+                               . ((isset($contenu['required']) and $contenu['required']) ? " required='required'" : "")
+                               . " />\n";
                }
        }
+
        return $fieldset;
 }
 
-function install_select_serveur()
-{
+function install_select_serveur() {
        $options = array();
        $dir = _DIR_RESTREINT . 'req/';
-       $d = @opendir($dir);
-       if (!$d) return array();
-       while ($f = readdir($d)) {
+       $d = opendir($dir);
+       if (!$d) {
+               return array();
+       }
+       while (($f = readdir($d)) !== false) {
                if ((preg_match('/^(.*)[.]php$/', $f, $s))
-               AND is_readable($f = $dir . $f)) {
+                       and is_readable($f = $dir . $f)
+               ) {
                        require_once($f);
                        $s = $s[1];
                        $v = 'spip_versions_' . $s;
-                       if (function_exists($v) AND $v()) {
-                         $titre = _T("install_select_type_$s");
-                               // proposer sqlite3 par defaut si dispo
-                               $selected = ($s=='sqlite3'?" selected='selected'":"");
-                         $options[$s] =  "<option value='$s'$selected>"
-                           . ($titre ? $titre : $s)
-                           ."</option>";
-                       } else spip_log("$s: portage indisponible");
+                       if (function_exists($v) and $v()) {
+                               $titre = _T("install_select_type_$s");
+                               // proposer mysql par defaut si dispo
+                               $checked = ($s == 'mysql' ? " checked='checked'" : "");
+                               $options[$s] = "<li><input type='radio' id='$s' value='$s' name='server_db'$checked>"
+                                       . "<label for='$s'>" . ($titre ? $titre : $s) . "</label></li>";
+                       } else {
+                               spip_log("$s: portage indisponible");
+                       }
                }
        }
        sort($options);
+
        return $options;
 }
 
-// http://doc.spip.org/@install_connexion_form
-function install_connexion_form($db, $login, $pass, $predef, $hidden, $etape, $jquery=true)
-{
+// http://code.spip.net/@install_connexion_form
+function install_connexion_form($db, $login, $pass, $predef, $hidden, $etape, $jquery = true) {
        $server_db = (is_string($predef[0])) ? $predef[0] : '';
 
        return generer_form_ecrire('install', (
-         "\n<input type='hidden' name='etape' value='$etape' />"
-       . $hidden
-       . (_request('echec')?
-                       ("<p><b>"._T('avis_connexion_echec_1').
-                       "</b></p><p>"._T('avis_connexion_echec_2')."</p><p style='font-size: small;'>"._T('avis_connexion_echec_3')."</p>")
-                       :"")
-
-       . ($jquery?http_script('',  'jquery.js'):'')
-       . http_script('
-               $(document).ready(function() {
+               "\n<input type='hidden' name='etape' value='$etape' />"
+               . $hidden
+               . (_request('echec') ?
+                       ("<p><b>" . _T('avis_connexion_echec_1') .
+                               "</b></p><p>" . _T('avis_connexion_echec_2') . "</p><p style='font-size: small;'>" . _T('avis_connexion_echec_3') . "</p>")
+                       : "")
+
+               . ($jquery ? http_script('', 'jquery.js') : '')
+               . http_script('
+               jQuery(function($) {
                        $("input[type=hidden][name=server_db]").each(function(){
                                if ($(this).attr("value").match("sqlite*")){
                                        $("#install_adresse_base_hebergeur,#install_login_base_hebergeur,#install_pass_base_hebergeur").hide();
                                }
                        });
-                       if ($("#sql_serveur_db").length) {
-                               if ($("#sql_serveur_db").attr("value").match("sqlite*"))
+                       if ($("input[name=server_db][checked]").attr("value").match("sqlite*"))
+                               $("#install_adresse_base_hebergeur,#install_login_base_hebergeur,#install_pass_base_hebergeur").hide();
+                       else
+                               $("#install_adresse_base_hebergeur,#install_login_base_hebergeur,#install_pass_base_hebergeur").show();
+                       $("input[name=server_db]").each(function(){
+                               $(this).on("change",function(){
+                                       if ($(this).prop("checked") && $(this).attr("value").match("sqlite*")) {
                                                $("#install_adresse_base_hebergeur,#install_login_base_hebergeur,#install_pass_base_hebergeur").hide();
-                                       else
-                                               $("#install_adresse_base_hebergeur,#install_login_base_hebergeur,#install_pass_base_hebergeur").show();
-                               $("#sql_serveur_db").change(function(){
-                                       if ($(this).find("option:selected").attr("value").match("sqlite*"))
-                                               $("#install_adresse_base_hebergeur,#install_login_base_hebergeur,#install_pass_base_hebergeur").hide();
-                                       else
+                                       }
+                                       if ($(this).prop("checked") && !$(this).attr("value").match("sqlite*")) {
                                                $("#install_adresse_base_hebergeur,#install_login_base_hebergeur,#install_pass_base_hebergeur").show();
+                                       }
                                });
-                       }
+                       });
                });')
 
-       . ($server_db
-               ? '<input type="hidden" name="server_db" value="'.$server_db.'" />'
+               . ($server_db
+                       ? '<input type="hidden" name="server_db" value="' . $server_db . '" />'
                        . (($predef[0])
-                          ?('<h3>'._T('install_serveur_hebergeur').'</h3>')
-                               :'')
-               : ('<fieldset><legend>'
-                  ._T('install_select_type_db')
-               . "</legend>"
-                       .'<label for="sql_serveur_db" class="p">'
-                       . _T('install_types_db_connus')
-                       // Passer l'avertissement SQLIte en  commentaire, on pourra facilement le supprimer par la suite sans changer les traductions.
-                       . "<br /><small>(". _T('install_types_db_connus_avertissement') .')</small>'
-                       .'</label>'
-               . "\n<div class='p center'><select name='server_db' id='sql_serveur_db' >\n"
-               .   join("\n", install_select_serveur())
-               . "\n</select></div></fieldset>")
-       )
-       . '<div id="install_adresse_base_hebergeur">'
-       . '<p>'. _T('texte_connexion_mysql').'</p>'
-       . ($predef[1]
-       ? '<h3>'._T('install_adresse_base_hebergeur').'</h3>'
-       : fieldset(_T('entree_base_donnee_1'),
-               array(
-                       'adresse_db' => array(
-                               'label' => $db[1],
-                               'valeur' => $db[0]
-                       ),
+                               ? ('<h3>' . _T('install_serveur_hebergeur') . '</h3>')
+                               : '')
+                       : ('<fieldset><legend>'
+                               . _T('install_select_type_db')
+                               . "</legend>"
+                               . '<p class="explication">'
+                               . _T('install_types_db_connus')
+                               // Passer l'avertissement SQLIte en  commentaire, on pourra facilement le supprimer par la suite sans changer les traductions.
+                               // . "<br /><small>(". _T('install_types_db_connus_avertissement') .')</small>'
+                               . '</p>'
+                               . "\n<div class='p'>\n<ul>\n"
+                               . join("\n", install_select_serveur())
+                               . "\n</ul>\n</div></fieldset>")
                )
-       )
-       )
-       . '</div>'
-
-       . '<div id="install_login_base_hebergeur">'
-       . ($predef[2]
-       ? '<h3>'._T('install_login_base_hebergeur').'</h3>'
-       : fieldset(_T('entree_login_connexion_1'),
-               array(
-                       'login_db' => array(
-                                       'label' => $login[1],
-                                       'valeur' => $login[0]
-                       ),
+               . '<div id="install_adresse_base_hebergeur">'
+               . '<p>' . _T('texte_connexion_mysql') . '</p>'
+               . ($predef[1]
+                       ? '<h3>' . _T('install_adresse_base_hebergeur') . '</h3>'
+                       : fieldset(_T('entree_base_donnee_1'),
+                               array(
+                                       'adresse_db' => array(
+                                               'label' => $db[1],
+                                               'valeur' => $db[0]
+                                       ),
+                               )
+                       )
                )
-       )
-       )
-       . '</div>'
-
-       . '<div id="install_pass_base_hebergeur">'
-       . ($predef[3]
-       ? '<h3>'._T('install_pass_base_hebergeur').'</h3>'
-       : fieldset(_T('entree_mot_passe_1'),
-               array(
-                       'pass_db' => array(
-                               'label' => $pass[1],
-                               'valeur' => $pass[0]
-                       ),
+               . '</div>'
+
+               . '<div id="install_login_base_hebergeur">'
+               . ($predef[2]
+                       ? '<h3>' . _T('install_login_base_hebergeur') . '</h3>'
+                       : fieldset(_T('entree_login_connexion_1'),
+                               array(
+                                       'login_db' => array(
+                                               'label' => $login[1],
+                                               'valeur' => $login[0]
+                                       ),
+                               )
+                       )
                )
-       )
-       )
-       . '</div>'
+               . '</div>'
+
+               . '<div id="install_pass_base_hebergeur">'
+               . ($predef[3]
+                       ? '<h3>' . _T('install_pass_base_hebergeur') . '</h3>'
+                       : fieldset(_T('entree_mot_passe_1'),
+                               array(
+                                       'pass_db' => array(
+                                               'label' => $pass[1],
+                                               'valeur' => $pass[0]
+                                       ),
+                               )
+                       )
+               )
+               . '</div>'
 
-       . bouton_suivant()));
+               . bouton_suivant()));
 
 }
 
 // 4 valeurs qu'on reconduit d'un script a l'autre
 // sauf s'ils sont predefinis.
 
-// http://doc.spip.org/@predef_ou_cache
-function predef_ou_cache($adresse_db, $login_db, $pass_db, $server_db)
-{
+// http://code.spip.net/@predef_ou_cache
+function predef_ou_cache($adresse_db, $login_db, $pass_db, $server_db) {
        return ((defined('_INSTALL_HOST_DB'))
                ? ''
-               : "\n<input type='hidden' name='adresse_db'  value=\"".spip_htmlspecialchars($adresse_db)."\" />"
+               : "\n<input type='hidden' name='adresse_db'  value=\"" . spip_htmlspecialchars($adresse_db) . "\" />"
        )
        . ((defined('_INSTALL_USER_DB'))
                ? ''
-               : "\n<input type='hidden' name='login_db' value=\"".spip_htmlspecialchars($login_db)."\" />"
+               : "\n<input type='hidden' name='login_db' value=\"" . spip_htmlspecialchars($login_db) . "\" />"
        )
        . ((defined('_INSTALL_PASS_DB'))
                ? ''
-               : "\n<input type='hidden' name='pass_db' value=\"".spip_htmlspecialchars($pass_db)."\" />"
+               : "\n<input type='hidden' name='pass_db' value=\"" . spip_htmlspecialchars($pass_db) . "\" />"
        )
 
        . ((defined('_INSTALL_SERVER_DB'))
                ? ''
-               : "\n<input type='hidden' name='server_db' value=\"".spip_htmlspecialchars($server_db)."\" />"
-          );
+               : "\n<input type='hidden' name='server_db' value=\"" . spip_htmlspecialchars($server_db) . "\" />"
+       );
 }
 
 // presentation des bases existantes
 
-// http://doc.spip.org/@install_etape_liste_bases
-function install_etape_liste_bases($server_db, $login_db, $disabled=array())
-{
+// http://code.spip.net/@install_etape_liste_bases
+function install_etape_liste_bases($server_db, $login_db, $disabled = array()) {
        $bases = $checked = array();
        $noms = sql_listdbs($server_db);
-       if (!$noms) return '';
+       if (!$noms) {
+               return '';
+       }
 
-       foreach ($noms as $nom){
+       foreach ($noms as $nom) {
                $id = spip_htmlspecialchars($nom);
                $dis = in_array($nom, $disabled) ? " disabled='disabled'" : '';
                $base = " name=\"choix_db\" value=\""
-                 . $nom
-                 . '"'
-                 . $dis
-                 . " type='radio' id='$id'";
+                       . $nom
+                       . '"'
+                       . $dis
+                       . " type='radio' id='$id'";
                $label = "<label for='$id'>"
-               . ($dis ? "<i>$nom</i>" : $nom)
-               . "</label>";
+                       . ($dis ? "<i>$nom</i>" : $nom)
+                       . "</label>";
 
-               if (!$checked AND !$dis AND
-                   (($nom == $login_db) OR
-                       ($GLOBALS['table_prefix'] == $nom))) {
+               if (!$checked and !$dis and
+                       (($nom == $login_db) or
+                               ($GLOBALS['table_prefix'] == $nom))
+               ) {
                        $checked = "<input$base checked='checked' />\n$label";
                } else {
-                       $bases[]= "<input$base />\n$label";
+                       $bases[] = "<input$base />\n$label";
                }
        }
 
-       if (!$bases && !$checked) return false;
+       if (!$bases && !$checked) {
+               return false;
+       }
 
-       if ($checked) {array_unshift($bases, $checked); $checked = true;}
+       if ($checked) {
+               array_unshift($bases, $checked);
+               $checked = true;
+       }
 
        return array($checked, $bases);
 }
 
-function install_propager($hidden)
-{
+function install_propager($hidden) {
        $res = '';
-       foreach($hidden as $k) {
+       foreach ($hidden as $k) {
                $v = spip_htmlentities(_request($k));
                $res .= "<input type='hidden' name='$k' value='$v' />";
        }
+
        return $res;
 }
-?>