114 lines
3.3 KiB
PHP
114 lines
3.3 KiB
PHP
<?php
|
|
|
|
/***************************************************************************\
|
|
* SPIP, Systeme de publication pour l'internet *
|
|
* *
|
|
* Copyright (c) 2001-2020 *
|
|
* Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
|
|
* *
|
|
* Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
|
|
* Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
|
|
\***************************************************************************/
|
|
|
|
if (!defined('_ECRIRE_INC_VERSION')) {
|
|
return;
|
|
}
|
|
|
|
// chargement des valeurs par defaut des champs du formulaire
|
|
function formulaires_oubli_charger_dist() {
|
|
$valeurs = array('oubli' => '', 'nobot' => '');
|
|
|
|
return $valeurs;
|
|
}
|
|
|
|
// https://code.spip.net/@message_oubli
|
|
function message_oubli($email, $param) {
|
|
$r = formulaires_oubli_mail($email);
|
|
|
|
if (is_array($r) and $r[1] and $r[1]['statut'] !== '5poubelle' and $r[1]['pass'] !== '') {
|
|
include_spip('inc/texte'); # pour corriger_typo
|
|
|
|
include_spip('action/inscrire_auteur');
|
|
$cookie = auteur_attribuer_jeton($r[1]['id_auteur']);
|
|
|
|
// l'url_reset doit etre une URL de confiance, on force donc un url_absolue sur adresse_site
|
|
include_spip('inc/filtres');
|
|
$msg = recuperer_fond(
|
|
'modeles/mail_oubli',
|
|
array(
|
|
'url_reset' => url_absolue(
|
|
generer_url_public('spip_pass', "$param=$cookie"),
|
|
$GLOBALS['meta']['adresse_site'] . '/'
|
|
)
|
|
)
|
|
);
|
|
include_spip('inc/notifications');
|
|
notifications_envoyer_mails($email, $msg);
|
|
}
|
|
|
|
return _T('pass_recevoir_mail');
|
|
}
|
|
|
|
// la saisie a ete validee, on peut agir
|
|
function formulaires_oubli_traiter_dist() {
|
|
|
|
$message = message_oubli(_request('oubli'), 'p');
|
|
|
|
return array('message_ok' => $message);
|
|
}
|
|
|
|
|
|
// fonction qu'on peut redefinir pour filtrer les adresses mail
|
|
// https://code.spip.net/@test_oubli
|
|
function test_oubli_dist($email) {
|
|
include_spip('inc/filtres'); # pour email_valide()
|
|
if (!email_valide($email)) {
|
|
return _T('pass_erreur_non_valide', array('email_oubli' => spip_htmlspecialchars($email)));
|
|
}
|
|
|
|
return array('mail' => $email);
|
|
}
|
|
|
|
function formulaires_oubli_verifier_dist() {
|
|
$erreurs = array();
|
|
|
|
$email = strval(_request('oubli'));
|
|
|
|
$r = formulaires_oubli_mail($email);
|
|
|
|
if (!is_array($r)) {
|
|
$erreurs['oubli'] = $r;
|
|
} else {
|
|
if (!$r[1]) {
|
|
spip_log("demande de reinitialisation de mot de passe pour $email non enregistre sur le site", "oubli");
|
|
} elseif ($r[1]['statut'] == '5poubelle' or $r[1]['pass'] == '') {
|
|
spip_log("demande de reinitialisation de mot de passe pour $email sans acces (poubelle ou pass vide)", "oubli");
|
|
}
|
|
}
|
|
|
|
if (_request('nobot')) {
|
|
$erreurs['message_erreur'] = _T('pass_rien_a_faire_ici');
|
|
}
|
|
|
|
return $erreurs;
|
|
}
|
|
|
|
function formulaires_oubli_mail($email) {
|
|
if (function_exists('test_oubli')) {
|
|
$f = 'test_oubli';
|
|
} else {
|
|
$f = 'test_oubli_dist';
|
|
}
|
|
$declaration = $f($email);
|
|
|
|
if (!is_array($declaration)) {
|
|
return $declaration;
|
|
} else {
|
|
include_spip('base/abstract_sql');
|
|
|
|
return array(
|
|
$declaration,
|
|
sql_fetsel('id_auteur,statut,pass', 'spip_auteurs', "login<>'' AND email =" . sql_quote($declaration['mail']))
|
|
);
|
|
}
|
|
}
|