0) $err = signature_modifier($id_signature); return array($id_signature,$err); } /** * Mettre a jour une signature existante * * @param int $id_signature * @param array $set * @return string */ function signature_modifier($id_signature, $set=null) { $err = ''; include_spip('inc/modifier'); $c = collecter_requests( // white list array( "nom_email","ad_email", "nom_site","url_site","message","statut" ), // black list array('statut','id_petition','date_time'), // donnees eventuellement fournies $set ); if ($err = objet_modifier_champs('signature', $id_signature, array( 'nonvide' => array('nom_email' => _T('info_sans_titre')) ), $c)) return $err; // Modification de statut $c = collecter_requests(array('statut','id_petition','date_time'),array(),$set); $err .= signature_instituer($id_signature, $c); return $err; } /** * Inserer une signature en base * @param int $id_petition * @return int */ function signature_inserer($id_petition) { // Si $id_petition vaut 0 ou n'est pas definie, echouer if (!$id_petition = intval($id_petition)) return 0; $champs = array( 'id_petition' => $id_petition, 'statut' => 'prepa', 'date_time' => date('Y-m-d H:i:s')); // Envoyer aux plugins $champs = pipeline('pre_insertion', array( 'args' => array( 'table' => 'spip_signatures', ), 'data' => $champs ) ); $id_signature = sql_insertq("spip_signatures", $champs); pipeline('post_insertion', array( 'args' => array( 'table' => 'spip_signatures', 'id_objet' => $id_signature ), 'data' => $champs ) ); return $id_signature; } // $c est un array ('statut', 'id_petition' = changement de petition) // il n'est pas autoriser de deplacer une signature // http://code.spip.net/@signature_instituer function signature_instituer($id_signature, $c, $calcul_rub=true) { include_spip('inc/autoriser'); include_spip('inc/modifier'); $row = sql_fetsel("S.statut, S.date_time, P.id_article", "spip_signatures AS S JOIN spip_petitions AS P ON S.id_petition=P.id_petition", "S.id_signature=".intval($id_signature)); $statut_ancien = $statut = $row['statut']; $date_ancienne = $date = $row['date_time']; $champs = array(); $d = isset($c['date_time'])?$c['date_time']:null; $s = isset($c['statut'])?$c['statut']:$statut; // cf autorisations dans inc/signature_instituer if ($s != $statut OR ($d AND $d != $date)) { $statut = $champs['statut'] = $s; // En cas de publication, fixer la date a "maintenant" // sauf si $c commande autre chose // ou si l'signature est deja date dans le futur // En cas de proposition d'un signature (mais pas depublication), idem if ($champs['statut'] == 'publie') { if ($d) $champs['date_time'] = $date = $d; else $champs['date_time'] = $date = date('Y-m-d H:i:s'); } // on peut redater une signature qu'on relance elseif($d) $champs['date_time'] = $date = $d; } // Envoyer aux plugins $champs = pipeline('pre_edition', array( 'args' => array( 'table' => 'spip_signatures', 'id_objet' => $id_signature, 'action'=>'instituer', 'statut_ancien' => $statut_ancien, ), 'data' => $champs ) ); if (!count($champs)) return; // Envoyer les modifs. sql_updateq('spip_signatures',$champs,'id_signature='.intval($id_signature)); // Invalider les caches include_spip('inc/invalideur'); suivre_invalideur("id='signature/$id_signature'"); suivre_invalideur("id='article/".$row['id_article']."'"); // Pipeline pipeline('post_edition', array( 'args' => array( 'table' => 'spip_signatures', 'id_objet' => $id_signature, 'action'=>'instituer', 'statut_ancien' => $statut_ancien, ), 'data' => $champs ) ); // Notifications if ($notifications = charger_fonction('notifications', 'inc')) { $notifications('instituersignature', $id_signature, array('statut' => $statut, 'statut_ancien' => $statut_ancien, 'date'=>$date) ); } return ''; // pas d'erreur } /** * Pour eviter le recours a un verrou (qui bloque l'acces a la base), * on commence par inserer systematiquement la signature * puis on demande toutes celles ayant la propriete devant etre unique * (mail ou site). S'il y en a plus qu'une on les retire sauf la premiere * En cas d'acces concurrents il y aura des requetes de retraits d'elements * deja detruits. Bizarre ? C'est mieux que de bloquer! * * http://code.spip.net/@signature_entrop * * @param string $where * @return array */ function signature_entrop($where) { $entrop = array(); $where .= " AND statut='publie'"; $res = sql_select('id_signature', 'spip_signatures', $where,'',"date_time desc"); $n = sql_count($res); if ($n>1) { while($r=sql_fetch($res)) $entrop[]=$r['id_signature']; // garder la premiere signature array_shift($entrop); } sql_free($res); if (count($entrop)){ sql_delete('spip_signatures', sql_in('id_signature', $entrop)); } return $entrop; } // obsolete function revision_signature($id_signature, $c=false) { return signature_modifier($id_signature,$c); } ?>