File "etape_ldap5.php"
Full path: /home/argothem/www/organecyberpresse/ecrire/install/etape_ldap5.php
File size: 4.13 KB
MIME-type: text/x-php
Charset: utf-8
<?php
/***************************************************************************\
* SPIP, Système de publication pour l'internet *
* *
* Copyright © avec tendresse depuis 2001 *
* Arnaud Martin, Antoine Pitrou, Philippe Rivière, Emmanuel Saint-James *
* *
* Ce programme est un logiciel libre distribué sous licence GNU/GPL. *
\***************************************************************************/
if (!defined('_ECRIRE_INC_VERSION')) {
return;
}
include_spip('inc/headers');
include_spip('auth/ldap');
function install_etape_ldap5_dist() {
etape_ldap5_save();
etape_ldap5_suite();
}
function etape_ldap5_save() {
$conn = null;
if (!@file_exists(_FILE_CONNECT_TMP)) {
redirige_url_ecrire('install');
}
ecrire_meta('ldap_statut_import', _request('statut_ldap'));
$conn_db = analyse_fichier_connection(_FILE_CONNECT_TMP);
if ($conn_db) {
[$adresse_db, $login_db, $pass_db, $sel_db, $server_db, $table_prefix, $auth, $charset] = $conn_db;
// il faudrait peut-être contrôler que $auth est bien vide ''
if (preg_match(',(.*):(.*),', (string) $adresse_db, $r)) {
[, $adresse_db, $port] = $r;
} else {
$port = '';
}
$auth_new = _FILE_LDAP;
// Ceci est nécessaire car on ne maitrise pas ce qui est ajouté au
// fichier de configuration
$orig_config = install_connexion(
$adresse_db,
$port,
$login_db,
$pass_db,
$sel_db,
$server_db,
$table_prefix,
$auth,
$charset
);
$new_config = install_connexion(
$adresse_db,
$port,
$login_db,
$pass_db,
$sel_db,
$server_db,
$table_prefix,
$auth_new,
$charset
);
lire_fichier(_FILE_CONNECT_TMP, $conn);
// on ne peut pas directement utiliser preg_replace pour ajouter
// $auth_new car on n'est pas censé connaître le format de la ligne de
// connexion ici
$new_conn = str_replace(
$orig_config,
$new_config,
$conn,
$count
);
// on ne casse pas le fichier de connexion si quelque chose se passe
// mal, peut-être faudrait-il afficher une erreur
if ($count == 1) {
ecrire_fichier(
_FILE_CONNECT_TMP,
$new_conn
);
}
}
$adresse_ldap = addcslashes(_request('adresse_ldap'), "'\\");
$login_ldap = addcslashes(_request('login_ldap'), "'\\");
$pass_ldap = addcslashes(_request('pass_ldap'), "'\\");
$port_ldap = addcslashes(_request('port_ldap'), "'\\");
$tls_ldap = addcslashes(_request('tls_ldap'), "'\\");
$protocole_ldap = addcslashes(_request('protocole_ldap'), "'\\");
$base_ldap = addcslashes(_request('base_ldap'), "'\\");
$base_ldap_text = addcslashes(_request('base_ldap_text'), "'\\");
$conn = "\$GLOBALS['ldap_base'] = '$base_ldap';\n"
. "\$GLOBALS['ldap_link'] = @ldap_connect('$adresse_ldap','$port_ldap');\n"
. "@ldap_set_option(\$GLOBALS['ldap_link'],LDAP_OPT_PROTOCOL_VERSION,'$protocole_ldap');\n"
. (($tls_ldap != 'oui') ? '' :
"@ldap_start_tls(\$GLOBALS['ldap_link']);\n")
. "@ldap_bind(\$GLOBALS['ldap_link'],'$login_ldap','$pass_ldap');\n";
$champs = is_array($GLOBALS['ldap_attributes']) ? $GLOBALS['ldap_attributes'] : [];
$res = '';
foreach ($champs as $champ => $v) {
$nom = 'ldap_' . $champ;
$val = trim(_request($nom));
if (preg_match('/^\w*$/', $val)) {
if ($val) {
$val = _q($val);
}
} else {
$val = 'array(' . _q(preg_split('/\W+/', $val)) . ')';
};
if ($val) {
$res .= "'$champ' => " . $val . ',';
}
}
$conn .= "\$GLOBALS['ldap_champs'] = array($res);\n";
install_fichier_connexion(_DIR_CONNECT . _FILE_LDAP, $conn);
}
function etape_ldap5_suite() {
$minipage = new Spip\Afficher\Minipage\Installation();
echo $minipage->installDebutPage(['onload' => 'document.getElementById(\'suivant\').focus();return false;']);
echo info_etape(
_T('info_ldap_ok'),
info_progression_etape(5, 'etape_ldap', 'install/')
);
echo generer_form_ecrire('install', (
"<input type='hidden' name='etape' value='3'>" .
"<input type='hidden' name='ldap_present' value='true'>"
. bouton_suivant()));
echo $minipage->installFinPage();
}