3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
6 * Copyright (c) 2001-2007 *
7 * Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
9 * Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
10 * Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
11 \***************************************************************************/
13 if (!defined("_ECRIRE_INC_VERSION")) return;
15 include_spip('inc/actions');
16 include_spip('inc/cookie');
18 // http://doc.spip.org/@auth_http
19 function auth_http($url) {
21 if (verifier_php_auth())
22 redirige_par_entete($url);
24 ask_php_auth(_T('info_connexion_refusee'),
25 _T('login_login_pass_incorrect'),
26 _T('login_retour_site'),
27 "url=".rawurlencode($url),
28 _T('login_nouvelle_tentative'),
29 (ereg(_DIR_RESTREINT_ABS
, $url)));
35 // http://doc.spip.org/@action_cookie_dist
36 function action_cookie_dist()
48 $session_login_hidden,
50 $session_password_md5,
59 // rejoue le cookie pour renouveler spip_session
60 if ($change_session == 'oui') {
61 $session = charger_fonction('session', 'inc');
67 // tentative de connexion en auth_http
68 if ($essai_auth_http AND !$ignore_auth_http) {
69 auth_http(($url ?
$url : _DIR_RESTREINT_ABS
), $essai_auth_http);
73 // en cas de login sur bonjour=oui, on tente de poser un cookie
74 // puis de passer au login qui diagnostiquera l'echec de cookie
76 if ($test_echec_cookie == 'oui') {
77 preg_match(',^[^/]*//[^/]*(.*)/$,',
80 spip_setcookie('spip_session', 'test_echec_cookie',0,$r[1]);
81 redirige_par_entete(generer_url_public('login',
82 "var_echec_cookie=oui&url="
83 . ($url ?
rawurlencode($url) : _DIR_RESTREINT_ABS
), true
));
86 unset ($cookie_session);
87 $redirect = ($url ?
$url : _DIR_RESTREINT_ABS
);
88 if ($essai_login == "oui") {
89 // Recuperer le login en champ hidden
90 if ($session_login_hidden AND !$session_login)
91 $session_login = $session_login_hidden;
93 $row_auteur = array();
96 // Essayer l'authentification par MySQL
97 $auth_spip = charger_fonction('auth_spip', 'inc', true
);
98 if ($auth_spip) $row_auteur = $auth_spip($session_login, $session_password);
100 // Marche pas: essayer l'authentification par LDAP si present
101 if (!$row_auteur AND $GLOBALS['ldap_present']) {
102 $auth_ldap = charger_fonction('auth_ldap', 'inc', true
);
103 if ($auth_ldap) $row_auteur = $auth_ldap($session_login, $session_password);
106 // Marche pas, renvoyer le formulaire avec message d'erreur si 2e fois
108 if (ereg(_DIR_RESTREINT_ABS
, $redirect))
109 $redirect = generer_url_public('login',
110 "var_login=$session_login", true
);
111 if ($session_password ||
$session_password_md5)
112 $redirect = parametre_url($redirect, 'var_erreur', 'pass', '&');
113 $redirect .= '&url=' . rawurlencode($url);
114 spip_log("echec login: $session_login");
116 spip_log("login de $session_login vers $redirect");
117 // Si on se connecte dans l'espace prive,
118 // ajouter "bonjour" (repere a peu pres les cookies desactives)
119 if (ereg(_DIR_RESTREINT_ABS
, $redirect)) {
120 $redirect .= ((false
!== strpos($redirect, "?")) ?
"&" : "?")
123 if ($row_auteur['statut'] == '0minirezo')
124 $cookie_admin = "@".$session_login;
126 $session = charger_fonction('session', 'inc');
127 $cookie_session = $session($row_auteur);
128 preg_match(',^[^/]*//[^/]*(.*)/$,',
132 if ($session_remember == 'oui')
133 spip_setcookie('spip_session', $cookie_session, time() +
3600 * 24 * 14,$r[1]);
135 spip_setcookie('spip_session', $cookie_session, 0, $r[1]);
137 $prefs = ($row_auteur['prefs']) ?
unserialize($row_auteur['prefs']) : array();
138 $prefs['cnx'] = ($session_remember == 'oui') ?
'perma' : '';
140 spip_query("UPDATE spip_auteurs SET prefs = " . _q(serialize($prefs)) . " WHERE id_auteur = " . $row_auteur['id_auteur']);
145 if ($cookie_admin == "non") {
147 $retour = generer_url_public('login',
148 'url='.rawurlencode($url), true
);
150 spip_setcookie('spip_admin', $spip_admin, time() - 3600 * 24);
151 $redirect = parametre_url($retour,'var_login','','&');
152 $redirect = parametre_url($redirect,'var_erreur','','&');
153 $redirect .= ((false
!== strpos($redirect, "?")) ?
"&" : "?")
156 else if ($cookie_admin AND $spip_admin != $cookie_admin) {
157 spip_setcookie('spip_admin', $cookie_admin, time() +
3600 * 24 * 14);
160 // changement de langue espace public
162 include_spip('inc/lang');
164 if (changer_langue($var_lang)) {
165 spip_setcookie('spip_lang', $var_lang, time() +
365 * 24 * 3600);
166 $redirect = parametre_url($redirect,'lang',$var_lang,'&');
170 // changer de langue espace prive avant le login (i.e. pas authentfie)
171 elseif ($var_lang_ecrire) {
172 include_spip('action/converser');
173 action_converser_post();
175 redirige_par_entete($redirect, true
);