API de gestion des liaisons (`editer_liens`)

SPIP 3 introduit une gestion générique des tables de liens d’un objet avec n’importe quel autre objet.

Table de lien

Les liens sont structurellement non symétriques : il partent d’un objet source pour aller vers n’importe quel objet destination.

Pour être associable en tant que source, un objet bidibule stocké dans une table spip_bidibules doit posséder une table spip_bidibules_liens qui possèdera un champ id_bidibule (même nom que la clé primaire de spip_bidibules) et deux champs id_objet et objet.
La table peut aussi comporter d’autres champs pour qualifier les liens.

API

L’API permet de gérer simplement les liens sans manipuler directement des requêtes SQL, et en offrant systématiquement des points d’entrée aux plugins qui peuvent ainsi savoir quand un lien est ajouté, supprimé, ou modifié et agir en conséquence.

Pour utiliser l’API il faut inclure action/editer_liens.php :

include_spip('action/editer_liens');

objet_associable

objet_associable($objet) teste si un objet peut être associé à d’autres via sa table de liens.

Si l’objet n’est pas associable (il n’a pas de table de liens dédiée), la fonction renvoie false.

Si l’objet est associable, la fonction renvoie un tableau composé du nom de la clé primaire (commune à la table de liens et à la table de l’objet), et le nom de la table de liens.

Par exemple (et par défaut dans SPIP) les auteurs, les documents, les mots sont des objets associables car ils disposent tous d’une table spip_xxx_liens.

Par contre, les articles ne sont pas associables car ils ne disposent pas de table spip_articles_liens. Cela signifie qu’on ne peut pas créer de liens partant des articles vers un autre objet quelconque. En revanche on peut créer un lien depuis un mot, un auteur ou un document vers un article.

objet_associer

objet_associer($objets_source, $objets_lies[, $qualif]) permet d’associer les $objets_lies aux $objets_source via leurs table de lien propres.

$objets_source
Les $objets_source doivent être tous associables au sens de la fonction objet_associable(). Les objets sources sont donc les pivots sur lesquels portent les liens.

Le format de $objets_source est commun a toutes les fonctions de manipulation de liens.
C’est un tableau dont

  • chaque clé correspond au nom de l’objet à associer
  • chaque valeur décrit le ou les id pour chaque objet. Les valeurs peuvent être :
    • le joker "*" qui désigne "tous les id déja dans la table de lien" (il a donc peu d’intérêt dans le cas de l’ajout de liens comme ici)
    • une valeur scalaire autre désigne un id précis
    • un tableau désigne une liste d’id (un tableau ne peut pas contenir le joker "*")
    • un tableau de deux éléments commençant par la valeur ’NOT’ désigne une condition exclusive : tous les id déjà dans la table de lien sauf ceux décrits dans la seconde valeur (qui peut être à son tour un scalaire ou un tableau)

$objets_lies
Le format de $objets_lies est commun a toutes les fonctions de manipulation de liens.
C’est un tableau dont

  • chaque clé correspond au nom de l’objet à associer. La valeur joker "*" désigne "tous les objets présents dans la table de lien" (peu d’intérêt dans le cas d’ajout de lien donc)
  • chaque valeur décrit le ou les id pour chaque objet. Les valeurs peuvent être :
    • le joker "*" qui désigne "tous les id déja dans la table de lien" (il a donc peu d’intérêt dans le cas de l’ajout de liens comme ici)
    • une valeur scalaire autre désigne un id précis
    • un tableau désigne une liste d’id (un tableau ne peut pas contenir le joker "*")
    • un tableau de deux éléments commençant par la valeur ’NOT’ désigne une condition exclusive : tous les id déjà dans la table de lien sauf ceux décrits dans la seconde valeur (qui peut être à son tour un scalaire ou un tableau)

$qualif
La fonction objet_associer peut prendre un troisième argument facultatif $qualif qui est un tableau associatif champ=>valeur avec lequel seront modifiés les liens ajoutés. Cela peut être utile si la table de lien dispose de champs supplémentaires qui décrivent les liens.

Si plusieurs liens sont créés en même temps, ils se voient appliquer tous les mêmes valeurs décrites dans $qualif

exemples
Les exemples ci-dessous sont valides :

objet_associer(["auteur"=>3], ["article"=>5]);
objet_associer(["auteur"=>3], ["article"=>[5, 6]]);
objet_associer(["auteur"=>[3, 4]], ["article"=>5]);
objet_associer(["auteur"=>[3, 4]], ["article"=>[5, 6]]);
objet_associer(["document"=>3], ["article"=>5], ['vu'=>'oui']);

La fonction renvoie le nombre de liens effectivement créés (certains liens pouvant déjà exister au moment de la tentative d’ajout, qui ne sont alors pas comptés).

objet_dissocier

objet_dissocier($objets_source,$objets_lies) permet de supprimer les liens entre les $objets_source et $objets_lies.

$objets_source
voir le format identique à celui décrit dans objet_associer

$objets_lies
voir le format identique à celui décrit dans objet_associer

exemples
Les exemples ci-dessous sont valides :

objet_dissocier(array("auteur"=>3), array("article"=>5));

/* Exemple pour associer un auteur à une liste d'article et uniquement à ceux là */
objet_associer(array("auteur"=>3), array("article"=>array(5,6)));
objet_dissocier(array("auteur"=>3), array("article"=>array('NOT', array(5,6))));

La fonction renvoie le nombre de liens effectivement supprimés.

objet_qualifier_liens

objet_qualifier_liens($objets_source,$objets_lies,$qualif) permet de modifier les valeurs des champs décrits dans $qualif sur les liens entre $objets_source et $objets_lies

$objets_source
voir le format identique à celui décrit dans objet_associer

$objets_lies
voir le format identique à celui décrit dans objet_associer

$qualif
voir le format identique à celui décrit dans objet_associer

exemples
Les exemples ci-dessous sont valides :

objet_qualifier(array("document"=>3), array("article"=>5), array('vu'=>'oui'));

La fonction renvoie le nombre de mise à jour en base ou false en cas d’échec.

objet_trouver_liens

objet_trouver_liens($objets_source,$objets_lies) permet de retrouver tous les liens de $objets_source vers $objets_lies.

$objets_source
voir le format identique à celui décrit dans objet_associer

$objets_lies
voir le format identique à celui décrit dans objet_associer

La fonction renvoie un tableau constitué d’un tableau associatif pour chaque lien trouvé. Ce dernier contient l’ensemble des champs du lien, auquel sont ajoutés une entrée objet=>id pour la source et la destination du lien, pour simplifier le traitement au retour (évite d’avoir à connaitre les clés primaires par exemple).

objet_optimiser_liens

objet_optimiser_liens($objets_source,$objets_lies) nettoie les liens restant entre $objets_source et $objets_lies lorsque l’un des deux n’existe plus (suppression en base de données).

Cette fonction est classiquement utilisée dans des fonctions crons de nettoyage de la base de données.

$objets_source
voir le format identique à celui décrit dans objet_associer

$objets_lies
voir le format identique à celui décrit dans objet_associer

La fonction renvoie le nombre de liens obsolètes nettoyés

objet_dupliquer_liens

objet_dupliquer_liens($objet,$id_source,$id_cible) va dupliquer tous les liens de l’$objet $id_source sur l’$objet $id_cible.

Pour cela, toutes les tables de liens de tous les objets connus seront parcourues pour trouver les liens depuis et vers l’$objet $id_source.

Chaque lien trouvé sera dupliqué en substituant $id_cible à $id_source

La fonction retourne le nombre de liens dupliqués.

Interface d’édition

Une interface générique #FORMULAIRE_EDITER_LIENS utilisable dans les squelettes permet l’édition des liens.
#FORMULAIRE_EDITER_LIENS{auteurs,article,23} installera le formulaire pour associer/dissocier des auteurs de l’article N°23.

Les liens sont portés par la table lien du premier objet passé en argument du formulaire (auteurs dans l’exemple ci-dessus).

On peut utiliser ce formulaire de plusieurs façons :

  • #FORMULAIRE_EDITER_LIENS{auteurs,article,23} pour associer des auteurs à l’article N°23, sur la table pivot spip_auteurs_liens
  • #FORMULAIRE_EDITER_LIENS{auteur,12,articles} pour associer des articles à l’auteur N°12, sur la table pivot spip_auteurs_liens
  • #FORMULAIRE_EDITER_LIENS{mot,15,auteurs} pour associer des auteurs au mot N°15, sur la table pivot spip_mots_liens
  • #FORMULAIRE_EDITER_LIENS{auteurs,mot,15} pour associer des auteurs au mot N°15, sur la table pivot spip_auteurs_liens

On peut donc, par la syntaxe d’appel, définir quels objets sont associé entre eux, ainsi que la table qui supporte les liens.

Remarque : il est possible de filtrer la liste des objets présentés selon la valeur de certains de leurs champs en passant celles-ci en 4ème argument dans un tableau associatif champ=>valeur :

#FORMULAIRE_EDITER_LIENS{auteurs,article,23,#ARRAY{statut,6forum}}

Ne proposera que les auteurs dont le statut est 6forum.

Pour fonctionner, ce formulaire nécessite 2 squelettes correspondant au type d’objet associé. Par exemple pour pouvoir associer ou dissocier des auteurs de n’importe quel autre objet, les squelettes prive/objets/liste/auteurs_lies.html et prive/objets/liste/auteurs_associer.html sont nécessaires au fonctionnement du formulaire. Ils présentent la liste des objets déjà associés ainsi que la sélection des objets à associer.
SPIP inclue nativement les vues nécessaires pour les auteurs, les rubriques, ainsi que les mots via le plugin mots.
Des plugins peuvent rendre cette interface disponible pour de nouveaux objets éditoriaux par la définition de ces deux squelettes.

Auteur cerdic, JLuc Publié le : Mis à jour : 22/05/24