[SPIP] +installation version 3.0.10
[lhc/web/www.git] / www / prive / formulaires / editer_auteur.php
1 <?php
2
3 if (!defined('_ECRIRE_INC_VERSION')) return;
4
5 include_spip('inc/actions');
6 include_spip('inc/editer');
7 include_spip('inc/filtres_ecrire'); // si on utilise le formulaire dans le public
8
9 // http://doc.spip.org/@inc_editer_mot_dist
10 function formulaires_editer_auteur_charger_dist($id_auteur='new', $retour='', $associer_objet='', $config_fonc='auteurs_edit_config', $row=array(), $hidden=''){
11 $valeurs = formulaires_editer_objet_charger('auteur',$id_auteur,0,0,$retour,$config_fonc,$row,$hidden);
12 $valeurs['new_login'] = $valeurs['login'];
13
14 return $valeurs;
15 }
16
17 /**
18 * Identifier le formulaire en faisant abstraction des parametres qui
19 * ne representent pas l'objet edite
20 */
21 function formulaires_editer_auteur_identifier_dist($id_auteur='new', $retour='', $associer_objet='', $config_fonc='auteurs_edit_config', $row=array(), $hidden=''){
22 return serialize(array(intval($id_auteur),$associer_objet));
23 }
24
25
26 // Choix par defaut des options de presentation
27 // http://doc.spip.org/@articles_edit_config
28 function auteurs_edit_config($row)
29 {
30 global $spip_lang;
31
32 $config = $GLOBALS['meta'];
33 $config['lignes'] = 8;
34 $config['langue'] = $spip_lang;
35
36 // pour instituer_auteur
37 $config['auteur'] = $row;
38
39 //$config['restreint'] = ($row['statut'] == 'publie');
40 $auth_methode = $row['source'];
41 include_spip('inc/auth');
42 include_spip('inc/autoriser');
43 $autoriser = autoriser('modifier','auteur',$row['id_auteur'],null, array('restreintes'=>true));
44 $config['edit_login'] =
45 (auth_autoriser_modifier_login($auth_methode) AND $autoriser);
46 $config['edit_pass'] =
47 (auth_autoriser_modifier_pass($auth_methode)
48 AND
49 ($GLOBALS['visiteur_session']['id_auteur'] == $row['id_auteur'] OR $autoriser)
50 );
51
52 return $config;
53 }
54
55 function formulaires_editer_auteur_verifier_dist($id_auteur='new', $retour='', $associer_objet='', $config_fonc='auteurs_edit_config', $row=array(), $hidden=''){
56 // auto-renseigner le nom si il n'existe pas, sans couper
57 titre_automatique('nom',array('email','login'),255);
58 // mais il reste obligatoire si on a rien trouve
59 $erreurs = formulaires_editer_objet_verifier('auteur',$id_auteur,array('nom'));
60
61 $auth_methode = sql_getfetsel('source','spip_auteurs','id_auteur='.intval($id_auteur));
62 $auth_methode = ($auth_methode ? $auth_methode : 'spip');
63 include_spip('inc/auth');
64
65 if ($email = _request('email')){
66 include_spip('inc/filtres');
67 include_spip('inc/autoriser');
68 // un redacteur qui modifie son email n'a pas le droit de le vider si il y en avait un
69 if (!autoriser('modifier','auteur',$id_auteur,null,array('email'=>'?'))
70 AND $GLOBALS['visiteur_session']['id_auteur']==$id_auteur
71 AND !strlen(trim($email))
72 AND $email!=($email_ancien=sql_getfetsel('email', 'spip_auteurs', 'id_auteur='.intval($id_auteur)))
73 ){
74 $erreurs['email'] = (($id_auteur==$GLOBALS['visiteur_session']['id_auteur'])?_T('form_email_non_valide'):_T('form_prop_indiquer_email'));
75 }
76 else if (!email_valide($email)){
77 $erreurs['email'] = (($id_auteur==$GLOBALS['visiteur_session']['id_auteur'])?_T('form_email_non_valide'):_T('form_prop_indiquer_email'));
78 }
79 }
80
81 if ($err = auth_verifier_login($auth_methode, _request('new_login'), $id_auteur)){
82 $erreurs['new_login'] = $err;
83 $erreurs['message_erreur'] .= $err;
84 }
85 else {
86 // pass trop court ou confirmation non identique
87 if ($p = _request('new_pass')) {
88 if ($p != _request('new_pass2')) {
89 $erreurs['new_pass'] = _T('info_passes_identiques');
90 $erreurs['message_erreur'] .= _T('info_passes_identiques');
91 }
92 elseif ($err = auth_verifier_pass($auth_methode, _request('new_login'),$p, $id_auteur)){
93 $erreurs['new_pass'] = $err;
94 $erreurs['message_erreur'] .= $err;
95 }
96 }
97 }
98 return $erreurs;
99 }
100
101 // http://doc.spip.org/@inc_editer_mot_dist
102 function formulaires_editer_auteur_traiter_dist($id_auteur='new', $retour='', $associer_objet='', $config_fonc='auteurs_edit_config', $row=array(), $hidden=''){
103 if (_request('saisie_webmestre') OR _request('webmestre'))
104 set_request('webmestre',_request('webmestre')?_request('webmestre'):'non');
105 $retour = parametre_url($retour, 'email_confirm','');
106
107 include_spip('inc/autoriser');
108 if (!autoriser('modifier','auteur',$id_auteur,null,array('email'=>'?'))){
109 $email_nouveau = _request('email');
110 set_request('email'); // vider la saisie car l'auteur n'a pas le droit de modifier cet email
111 // mais si c'est son propre profil on lui envoie un email à l'adresse qu'il a indique
112 // pour qu'il confirme qu'il possede bien cette adresse
113 // son clic sur l'url du message permettre de confirmer le changement
114 // et de revenir sur son profil
115 if ($GLOBALS['visiteur_session']['id_auteur']==$id_auteur
116 AND $email_nouveau!=($email_ancien=sql_getfetsel('email', 'spip_auteurs', 'id_auteur='.intval($id_auteur)))){
117 $envoyer_mail = charger_fonction('envoyer_mail','inc');
118 $texte = _T('form_auteur_mail_confirmation',
119 array('url'=>generer_action_auteur('confirmer_email', $email_nouveau,parametre_url($retour, 'email_modif','ok'))));
120 $envoyer_mail($email_nouveau,_T('form_auteur_confirmation'),$texte);
121 set_request('email_confirm',$email_nouveau);
122 if ($email_ancien)
123 $envoyer_mail($email_ancien,_T('form_auteur_confirmation'),_T('form_auteur_envoi_mail_confirmation',array('email'=>$email_nouveau)));
124 $retour = parametre_url($retour, 'email_confirm',$email_nouveau);
125 }
126 }
127
128 $res = formulaires_editer_objet_traiter('auteur',$id_auteur,0,0,$retour,$config_fonc,$row,$hidden);
129
130 // Un lien auteur a prendre en compte ?
131 if ($associer_objet AND $id_auteur=$res['id_auteur']){
132 $objet = '';
133 if (intval($associer_objet)){
134 $objet='article';
135 $id_objet = intval($associer_objet);
136 }
137 elseif(preg_match(',^\w+\|[0-9]+$,',$associer_objet)){
138 list($objet,$id_objet) = explode('|',$associer_objet);
139 }
140 if ($objet AND $id_objet AND autoriser('modifier',$objet,$id_objet)){
141 include_spip('action/editer_auteur');
142 auteur_associer($id_auteur, array($objet => $id_objet));
143 if (isset($res['redirect']))
144 $res['redirect'] = parametre_url ($res['redirect'], "id_lien_ajoute", $id_auteur, '&');
145 }
146 }
147
148 return $res;
149 }
150
151 ?>