a4c68fdca782e1b5805d57a2265122a93b491fae
[ptitvelo/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 include_spip('inc/filtres');
65
66 if (!nom_acceptable(_request('nom'))) {
67 $erreurs['nom'] = _T("info_nom_pas_conforme");
68 }
69
70 if ($email = _request('email')){
71 include_spip('inc/autoriser');
72 // un redacteur qui modifie son email n'a pas le droit de le vider si il y en avait un
73 if (!autoriser('modifier','auteur',$id_auteur,null,array('email'=>'?'))
74 AND $GLOBALS['visiteur_session']['id_auteur']==$id_auteur
75 AND !strlen(trim($email))
76 AND $email!=($email_ancien=sql_getfetsel('email', 'spip_auteurs', 'id_auteur='.intval($id_auteur)))
77 ){
78 $erreurs['email'] = (($id_auteur==$GLOBALS['visiteur_session']['id_auteur'])?_T('form_email_non_valide'):_T('form_prop_indiquer_email'));
79 }
80 else if (!email_valide($email)){
81 $erreurs['email'] = (($id_auteur==$GLOBALS['visiteur_session']['id_auteur'])?_T('form_email_non_valide'):_T('form_prop_indiquer_email'));
82 }
83 }
84
85 if (preg_match(",^\s*javascript,i", _request('url_site'))) {
86 $erreurs['url_site'] = _T('info_url_site_pas_conforme');
87 }
88
89 if ($err = auth_verifier_login($auth_methode, _request('new_login'), $id_auteur)){
90 $erreurs['new_login'] = $err;
91 $erreurs['message_erreur'] .= $err;
92 }
93 else {
94 // pass trop court ou confirmation non identique
95 if ($p = _request('new_pass')) {
96 if ($p != _request('new_pass2')) {
97 $erreurs['new_pass'] = _T('info_passes_identiques');
98 $erreurs['message_erreur'] .= _T('info_passes_identiques');
99 }
100 elseif ($err = auth_verifier_pass($auth_methode, _request('new_login'),$p, $id_auteur)){
101 $erreurs['new_pass'] = $err;
102 $erreurs['message_erreur'] .= $err;
103 }
104 }
105 }
106 return $erreurs;
107 }
108
109 // http://doc.spip.org/@inc_editer_mot_dist
110 function formulaires_editer_auteur_traiter_dist($id_auteur='new', $retour='', $associer_objet='', $config_fonc='auteurs_edit_config', $row=array(), $hidden=''){
111 if (_request('saisie_webmestre') OR _request('webmestre'))
112 set_request('webmestre',_request('webmestre')?_request('webmestre'):'non');
113 $retour = parametre_url($retour, 'email_confirm','');
114
115 include_spip('inc/autoriser');
116 if (!autoriser('modifier','auteur',$id_auteur,null,array('email'=>'?'))){
117 $email_nouveau = _request('email');
118 set_request('email'); // vider la saisie car l'auteur n'a pas le droit de modifier cet email
119 // mais si c'est son propre profil on lui envoie un email à l'adresse qu'il a indique
120 // pour qu'il confirme qu'il possede bien cette adresse
121 // son clic sur l'url du message permettre de confirmer le changement
122 // et de revenir sur son profil
123 if ($GLOBALS['visiteur_session']['id_auteur']==$id_auteur
124 AND $email_nouveau!=($email_ancien=sql_getfetsel('email', 'spip_auteurs', 'id_auteur='.intval($id_auteur)))){
125 $envoyer_mail = charger_fonction('envoyer_mail','inc');
126 $texte = _T('form_auteur_mail_confirmation',
127 array('url'=>generer_action_auteur('confirmer_email', $email_nouveau,parametre_url($retour, 'email_modif','ok'))));
128 $envoyer_mail($email_nouveau,_T('form_auteur_confirmation'),$texte);
129 set_request('email_confirm',$email_nouveau);
130 if ($email_ancien)
131 $envoyer_mail($email_ancien,_T('form_auteur_confirmation'),_T('form_auteur_envoi_mail_confirmation',array('email'=>$email_nouveau)));
132 $retour = parametre_url($retour, 'email_confirm',$email_nouveau);
133 }
134 }
135
136 $res = formulaires_editer_objet_traiter('auteur',$id_auteur,0,0,$retour,$config_fonc,$row,$hidden);
137
138 // Un lien auteur a prendre en compte ?
139 if ($associer_objet AND $id_auteur=$res['id_auteur']){
140 $objet = '';
141 if (intval($associer_objet)){
142 $objet='article';
143 $id_objet = intval($associer_objet);
144 }
145 elseif(preg_match(',^\w+\|[0-9]+$,',$associer_objet)){
146 list($objet,$id_objet) = explode('|',$associer_objet);
147 }
148 if ($objet AND $id_objet AND autoriser('modifier',$objet,$id_objet)){
149 include_spip('action/editer_auteur');
150 auteur_associer($id_auteur, array($objet => $id_objet));
151 if (isset($res['redirect']))
152 $res['redirect'] = parametre_url ($res['redirect'], "id_lien_ajoute", $id_auteur, '&');
153 }
154 }
155
156 return $res;
157 }
158
159 ?>