0){
# cf. GROS HACK
# recuperer l'eventuel logo charge avant la creation
# ils ont un id = 0-id_auteur de la session
$id_hack = 0 - $GLOBALS['visiteur_session']['id_auteur'];
$chercher_logo = charger_fonction('chercher_logo', 'inc');
if (list($logo) = $chercher_logo($id_hack, 'id_auteur', 'on'))
rename($logo, str_replace($id_hack, $id_auteur, $logo));
if (list($logo) = $chercher_logo($id_hack, 'id_auteur', 'off'))
rename($logo, str_replace($id_hack, $id_auteur, $logo));
}
}
// Enregistre l'envoi dans la BD
if ($id_auteur > 0)
$err = auteurs_set($id_auteur);
if ($redirect = _request('redirect')) {
if ($err){
$ret = ('&redirect=' . $redirect);
spip_log("echec editeur auteur: " . join(' ',$echec));
$echec = '&echec=' . join('@@@', $echec);
$redirect = generer_url_ecrire('auteur_infos',"id_auteur=$id_auteur$echec$ret",'&');
}
else
$redirect = urldecode($redirect);
$redirect = parametre_url($redirect,'id_auteur', $id_auteur, '&');
include_spip('inc/headers');
redirige_par_entete($redirect);
}
else
return array($id_auteur,$err);
$redirect = _request('redirect');
}
function insert_auteur($source=null) {
// Ce qu'on va demander comme modifications
$champs = array();
$champs['source'] = $source?$source:'spip';
$champs['login'] = '';
$champs['statut'] = '5poubelle'; // inutilisable tant qu'il n'a pas ete renseigne et institue
$champs['webmestre'] = 'non';
// Envoyer aux plugins
$champs = pipeline('pre_insertion',
array(
'args' => array(
'table' => 'spip_auteurs',
),
'data' => $champs
)
);
$id_auteur = sql_insertq("spip_auteurs", $champs);
pipeline('post_insertion',
array(
'args' => array(
'table' => 'spip_auteurs',
'id_objet' => $id_auteur
),
'data' => $champs
)
);
return $id_auteur;
}
// Appelle toutes les fonctions de modification d'un auteur
function auteurs_set($id_auteur, $set = null) {
$err = '';
if (is_null($set)){
$c = array();
foreach (array(
'nom','email','bio',
'nom_site','url_site',
'imessage','pgp',
) as $champ)
$c[$champ] = _request($champ,$set);
}
else{
$c = $set;
unset($c['webmestre']);
unset($c['pass']);
unset($c['login']);
}
include_spip('inc/modifier');
revision_auteur($id_auteur, $c);
// Modification de statut, changement de rubrique ?
$c = array();
foreach (array(
'statut', 'new_login','new_pass','login','pass','webmestre','restreintes','id_parent'
) as $champ)
if (_request($champ,$set))
$c[preg_replace(',^new_,','',$champ)] = _request($champ,$set);
$err .= instituer_auteur($id_auteur, $c);
// Un lien auteur a prendre en compte ?
$err .= auteur_referent($id_auteur, array('article' => _request('lier_id_article',$set)));
return $err;
}
function auteur_referent($id_auteur,$c){
foreach($c as $objet => $id_objet){
if ($id_objet=intval($id_objet)){
$table = table_objet($objet);
$primary = id_table_objet($objet);
// Lier a un article sur lequel on a une liaison possible
if (in_array($table, array('articles','rubriques','messages'))){
sql_insertq("spip_auteurs_$table", array($primary => $id_objet, 'id_auteur' =>$id_auteur));
}
}
}
return ''; // pas d'erreur
}
// http://doc.spip.org/@instituer_auteur
function instituer_auteur($id_auteur, $c) {
if (!$id_auteur=intval($id_auteur))
return false;
// commencer par traiter les cas particuliers des logins et pass
// avant le changement de statut eventuel
if (isset($c['login']) OR isset($c['pass'])){
$auth_methode = sql_getfetsel('source','spip_auteurs','id_auteur='.intval($id_auteur));
include_spip('inc/auth');
if (isset($c['login']))
auth_modifier_login($auth_methode, $c['login'], $id_auteur);
if (isset($c['pass'])){
$c['login'] = sql_getfetsel('login','spip_auteurs','id_auteur='.intval($id_auteur));
auth_modifier_pass($auth_methode, $c['login'], $c['pass'], $id_auteur);
}
}
$champs = array();
$statut = $statut_ancien = sql_getfetsel('statut','spip_auteurs','id_auteur='.intval($id_auteur));
if (isset($c['statut'])
AND (($statut_ancien == 'nouveau') OR autoriser('modifier', 'auteur', $id_auteur,null, array('statut' => '?'))))
$statut = $champs['statut'] = $c['statut'];
// Restreindre avant de declarer l'auteur
// (section critique sur les droits)
if ($c['id_parent']) {
if (is_array($c['restreintes']))
$c['restreintes'][] = $c['id_parent'];
else
$c['restreintes'] = array($c['id_parent']);
}
if (isset($c['webmestre'])
AND autoriser('modifier', 'auteur', $id_auteur,null, array('webmestre' => '?')))
$champs['webmestre'] = $c['webmestre']=='oui'?'oui':'non';
// Envoyer aux plugins
$champs = pipeline('pre_edition',
array(
'args' => array(
'table' => 'spip_auteurs',
'id_objet' => $id_auteur,
'action' => 'instituer',
),
'data' => $champs
)
);
if (is_array($c['restreintes'])
AND autoriser('modifier', 'auteur', $id_auteur, NULL, array('restreint'=>$c['restreintes']))) {
sql_delete("spip_auteurs_rubriques", "id_auteur=".sql_quote($id_auteur));
foreach (array_unique($c['restreintes']) as $id_rub)
if ($id_rub = intval($id_rub)) // si '0' on ignore
sql_insertq('spip_auteurs_rubriques', array('id_auteur' => $id_auteur, 'id_rubrique'=>$id_rub));
}
if (!count($champs)) return;
sql_updateq('spip_auteurs', $champs , 'id_auteur='.$id_auteur);
include_spip('inc/modifier');
sql_updateq('spip_auteurs',$champs,'id_auteur='.$id_auteur);
// Invalider les caches
include_spip('inc/invalideur');
suivre_invalideur("id='id_auteur/$id_auteur'");
// Pipeline
pipeline('post_edition',
array(
'args' => array(
'table' => 'spip_auteurs',
'id_objet' => $id_auteur,
'action' => 'instituer',
),
'data' => $champs
)
);
// Notifications
if ($notifications = charger_fonction('notifications', 'inc')) {
$notifications('instituerauteur', $id_auteur,
array('statut' => $statut, 'statut_ancien' => $statut_ancien)
);
}
return ''; // pas d'erreur
}
?>