$saisie) {
$id = isset($args['id']) ? $args['id'] : $args['id_objet'];
if (!autoriser($faire . 'extra', $quoi, $id, '', array(
'type' => $quoi,
'id_objet' => $id,
'contexte' => isset($args['contexte']) ? $args['contexte'] : array(),
'table' => table_objet_sql($quoi),
'saisie' => $saisie,
'champ' => $saisie['options']['nom'],
))) {
// on n'est pas autorise
unset($saisies[$cle]);
}
else
{
// on est autorise
// on teste les sous-elements
if (isset($saisie['saisies']) and $saisie['saisies']) {
$saisies['saisies'] = champs_extras_autorisation($faire, $quoi, $saisie['saisies'], $args);
}
}
}
return $saisies;
}
/**
* Ajoute pour chaque saisie de type SQL un drapeau (input hidden)
* permettant de retrouver les saisies editées.
*
* Particulièrement utile pour les checkbox qui ne renvoient
* rien si on les décoche.
*
* @param array $saisies
* Liste de saisies
* @return array $saisies
* Saisies complétées des drapeaux d'édition
**/
function champs_extras_ajouter_drapeau_edition($saisies) {
$saisies_sql = saisies_lister_avec_sql($saisies);
foreach ($saisies_sql as $saisie) {
$nom = $saisie['options']['nom'];
$saisies[] = array(
'saisie' => 'hidden',
'options' => array(
'nom' => "cextra_$nom",
'defaut' => 1
)
);
}
return $saisies;
}
// ---------- pipelines -----------
/**
* Ajouter les champs extras sur les formulaires CVT editer_xx
*
* Liste les champs extras de l'objet, et s'il y en a les ajoute
* sur le formulaire d'édition en ayant filtré uniquement les saisies
* que peut voir le visiteur et en ayant ajouté des champs hidden
* servant à champs extras.
*
* @pipeline editer_contenu_objet
* @param array $flux Données du pipeline
* @return array Données du pipeline
**/
function cextras_editer_contenu_objet($flux){
// recuperer les saisies de l'objet en cours
$objet = $flux['args']['type'];
include_spip('inc/cextras');
if ($saisies = champs_extras_objet( table_objet_sql($objet) )) {
// filtrer simplement les saisies que la personne en cours peut voir
$saisies = champs_extras_autorisation('modifier', $objet, $saisies, $flux['args']);
// pour chaque saisie presente, de type champs extras (hors fieldset et autres)
// ajouter un flag d'edition
$saisies = champs_extras_ajouter_drapeau_edition($saisies);
// ajouter au formulaire
$ajout = recuperer_fond('inclure/generer_saisies', array_merge($flux['args']['contexte'], array('saisies'=>$saisies)));
$flux['data'] = preg_replace('%()%is', '
'."\n".'$1', $flux['data']);
}
return $flux;
}
/**
* Ajouter les champs extras soumis par les formulaire CVT editer_xx
*
* Pour chaque champs extras envoyé par le formulaire d'édition,
* ajoute les valeurs dans l'enregistrement à effectuer.
*
* @pipeline pre_edition
* @param array $flux Données du pipeline
* @return array Données du pipeline
**/
function cextras_pre_edition($flux){
include_spip('inc/cextras');
include_spip('inc/saisies_lister');
$table = $flux['args']['table'];
if ($saisies = champs_extras_objet( $table )) {
// Restreindre les champs postés en fonction des autorisations de les modifier
// au cas où un malin voudrait en envoyer plus que le formulaire ne demande
$saisies = champs_extras_autorisation('modifier', objet_type($table), $saisies, $flux['args']);
$saisies = saisies_lister_avec_sql($saisies);
foreach ($saisies as $saisie) {
$nom = $saisie['options']['nom'];
if (_request('cextra_' . $nom)) {
$extra = _request($nom);
if (is_array($extra)) {
$extra = join(',' , $extra);
}
$flux['data'][$nom] = corriger_caracteres($extra);
}
}
}
return $flux;
}
/**
* Ajouter les champs extras sur la visualisation de l'objet
*
* S'il y a des champs extras sur l'objet, la fonction les ajoute
* à la vue de l'objet, en enlevant les saisies que la personne n'a
* pas l'autorisation de voir.
*
* @pipeline afficher_contenu_objet
* @param array $flux Données du pipeline
* @return array Données du pipeline
**/
function cextras_afficher_contenu_objet($flux){
// recuperer les saisies de l'objet en cours
$objet = $flux['args']['type'];
include_spip('inc/cextras');
if ($saisies = champs_extras_objet( $table = table_objet_sql($objet) )) {
// ajouter au contexte les noms et valeurs des champs extras
$saisies_sql = saisies_lister_avec_sql($saisies);
$valeurs = sql_fetsel(array_keys($saisies_sql), $table, id_table_objet($table) . '=' . sql_quote($flux['args']['id_objet']));
if (!$valeurs) {
$valeurs = array();
} else {
// on applique les eventuels traitements definis
// /!\ La saisies-vues/_base applique |propre par defaut si elle ne trouve pas de saisie
// Dans ce cas, certains traitements peuvent être effectués 2 fois !
$saisies_traitees = saisies_lister_avec_traitements($saisies_sql);
unset($saisies_sql);
// Fournir $connect et $Pile[0] au traitement si besoin (l'evil eval)
$connect = '';
$Pile = array(0 => (isset($flux['args']['contexte']) ? $flux['args']['contexte'] : array()));
foreach ($saisies_traitees as $saisie) {
$traitement = $saisie['options']['traitements'];
$traitement = defined($traitement) ? constant($traitement) : $traitement;
$nom = $saisie['options']['nom'];
list($avant, $apres) = explode('%s', $traitement);
eval('$val = ' . $avant . ' $valeurs[$nom] ' . $apres . ';');
$valeurs[$nom] = $val;
}
}
$contexte = isset($flux['args']['contexte']) ? $flux['args']['contexte'] : array();
$contexte = array_merge($contexte, $valeurs);
// restreindre la vue selon les autorisations
$saisies = champs_extras_autorisation('voir', $objet, $saisies, $flux['args']);
// ajouter les vues
$flux['data'] .= recuperer_fond('inclure/voir_saisies', array_merge($contexte, array(
'saisies' => $saisies,
'valeurs' => $valeurs,
)));
}
return $flux;
}
/**
* Vérification de la validité des champs extras
*
* Lorsqu'un formulaire 'editer_xx' se présente, la fonction effectue,
* pour chaque champs extra les vérifications prévues dans la
* définition de la saisie, et retourne les éventuelles erreurs rencontrées.
*
* @pipeline formulaire_verifier
* @param array $flux Données du pipeline
* @return array Données du pipeline
**/
function cextras_formulaire_verifier($flux){
$form = $flux['args']['form'];
if (strncmp($form, 'editer_', 7) !== 0) {
return $flux;
}
$objet = substr($form, 7);
if ($saisies = champs_extras_objet( $table = table_objet_sql($objet) )) {
include_spip('inc/autoriser');
include_spip('inc/saisies');
// restreindre les saisies selon les autorisations
$id_objet = $flux['args']['args'][0]; // ? vraiment toujours ?
$saisies = champs_extras_autorisation('modifier', $objet, $saisies, array_merge($flux['args'], array(
'id' => $id_objet,
'contexte' => array()))); // nous ne connaissons pas le contexte dans ce pipeline
// restreindre les vérifications aux saisies enregistrables
$saisies = saisies_lister_avec_sql($saisies);
$verifier = charger_fonction('verifier', 'inc', true);
foreach ($saisies as $saisie) {
// verifier obligatoire
$nom = $saisie['options']['nom'];
if (isset($saisie['options']['obligatoire']) and $saisie['options']['obligatoire']
and !_request($nom))
{
$flux['data'][$nom] = _T('info_obligatoire');
// verifier (api) + normalisation
} elseif ($verifier
AND isset($saisie['verifier']['type'])
AND $verif = $saisie['verifier']['type'])
{
$options = isset($saisie['verifier']['options']) ? $saisie['verifier']['options'] : array();
$normaliser = null;
$valeur = _request($nom);
if ($erreur = $verifier($valeur, $verif, $options, $normaliser)) {
$flux['data'][$nom] = $erreur;
// si une valeur de normalisation a ete transmis, la prendre.
} elseif (!is_null($normaliser)) {
set_request($nom, $normaliser);
} else {
// [FIXME] exceptions connues de vérifications (pour les dates entre autres)
// en attendant une meilleure solution !
//
// Lorsque le champ n'est pas rempli dans le formulaire
// alors qu'une normalisation est demandée,
// verifier() sort sans indiquer d'erreur (c'est normal).
//
// Sauf que la donnée alors soumise à SQL sera une chaine vide,
// ce qui ne correspond pas toujours à ce qui est attendu.
if ((is_string($valeur) and !strlen($valeur) or (is_array($valeur) and $saisie['saisie']=='date'))
and isset($options['normaliser'])
and $norme = $options['normaliser']) {
// Charger la fonction de normalisation théoriquement dans verifier/date
// et si on en trouve une, obtenir la valeur normalisée
// qui est théoriquement la valeur par défaut, puisque $valeur est vide
include_spip("verifier/$verif");
if ($normaliser = charger_fonction("${verif}_${norme}", "normaliser", true)) {
$erreur = null;
$defaut = $normaliser($valeur, $options, $erreur);
if (is_null($erreur)) {
set_request($nom, $defaut);
} else {
// on affecte l'erreur, mais il est probable que
// l'utilisateur ne comprenne pas grand chose
$flux['data'][$nom] = $erreur;
}
} else {
include_spip('inc/cextras');
extras_log("Fonction de normalisation pour ${verif}_${norme} introuvable");
}
}
}
}
}
}
return $flux;
}
/**
* Insertion dans le pipeline revisions_chercher_label (Plugin révisions)
* Trouver le bon label à afficher sur les champs dans les listes de révisions
*
* Si un champ est un champ extra, son label correspond au label défini du champs extra
*
* @pipeline revisions_chercher_label
* @param array $flux Données du pipeline
* @return array Données du pipeline
**/
function cextras_revisions_chercher_label($flux){
$table = table_objet_sql($flux['args']['objet']);
$saisies_tables = champs_extras_objet($table);
foreach($saisies_tables as $champ){
if($champ['options']['nom'] == $flux['args']['champ']){
$flux['data'] = $champ['options']['label'];
break;
}
}
return $flux;
}
?>