Drupal

Drupal est un système de gestion de contenu (CMS) libre et open-source publié sous la licence publique générale GNU et écrit en PHP.

Historique

Dries Buytaert, développeur initial du projet à partir de 2000 à l’université d’Anvers, le définit comme « assembleur rapide de site web » (rapid website assembler). Il est utilisable tel quel sur toute base LAMP, WAMP, XAMPP ou MAMP, mais il est largement personnalisable et programmable ensuite. D’après son créateur, environ 500 000 sites l’utilisaient déjà dès septembre 2009.

En 2009, il est classé 1er du concours organisé par la société britannique Packt (en) dans la catégorie Best Open Source PHP CMS suivi par WordPress et Joomla!. Il fait également son entrée en première position dans le Hall of Fame Award nouvellement créé (suivi par Joomla!).

En 2010, Angela Byron annonce que Drupal équipe à peu près 1 % des sites Internet mondiaux.

En mai 2014 la société Acquia (dédiée à Drupal et créée par son fondateur) lève 50 millions de dollars auprès de New Enterprise Associates (NEA) et Split Rock Partners.

En 2018, Drupal est utilisé par 3,5% des sites Internet mondiaux. C’est le 3e système de gestion de contenu le plus utilisé derrière WordPress et Joomla.

Principes

Drupal peut être utilisé à quatre niveaux différents :

  1. Tel quel : une fois celui-ci installé et paramétré, il est utilisable pour créer du contenu structuré et annotable par des utilisateurs qui peuvent s’enregistrer sur le site. Les menus du site ont alors un aspect standard.
  2. Personnalisation simple : il est ensuite possible de personnaliser l’emplacement d’affichage ou l’affichage lui-même, de composants visuels standards (date et heure, derniers posts, nombre de connectés, etc.) ainsi que le thème d’affichage (terme expliqué plus bas) du site.
  3. Extension par ajouts externes : ajout, paramétrage et personnalisation de modules optionnels n’appartenant pas au noyau. À ce stade et au suivant, il n’est pas rare que le développeur du site écrive aussi un thème de présentation qui lui soit propre.
  4. Extension par développement interne : écriture de nouveaux modules régis par la GPL, qu’il est souvent efficace (mais nullement obligatoire) de présenter ensuite à la communauté afin que celle-ci puisse participer à leur évolution.

Drupal lui-même utilise une base de données – comprenant typiquement 60 à 300 tables selon les modules activés – et une hiérarchie de fonctions toutes substituables permettant au développeur d’application expérimenté de réécrire la seule partie qu’il désire modifier, et uniquement au niveau d’abstraction auquel il s’intéresse, sans toucher au reste. La bonne ou la mauvaise connaissance du niveau exact auquel intervenir peut diviser ou multiplier le temps de réalisation d’un facteur 10 ou plus.

Drupal comporte environ 4000 fonctions d’API, mais le site api.drupal.org permet de les retrouver en accès direct par une partie quelconque du contenu de leur nom. Dans la pratique, un module simple peut fort bien n’en utiliser qu’une dizaine, voire moins.

Contenus, traitements, présentation

Contenus, ou nœuds

Drupal nomme tout contenu qu’il gère un « nœud ». Une page d’article sera par exemple un nœud. Une page de livre aussi.

Ce nœud possédera d’une part un type : forum, article de fond, information brève, tutoriel, blog, commentaire, formulaire de saisie, livre collaboratif, image ou galerie d’images, sondage interactif, page de wiki, description d’article à vendre en ligne, petite annonce classée, etc. : la forme n’est plus assujettie à une architecture prédéterminée, ce qui rend le contenu aisément reconfigurable. En contrepartie de cette liberté, le concepteur doit se familiariser avec sa logique particulière.

Le nœud possédera par ailleurs, conformément aux spécifications de son type, des champs : nom, type, date, auteur, image éventuelle, corps, votes de la communauté sur son contenu, etc.
La taxinomie peut comporter des ascendances multiples

Chaque nœud peut être attaché simultanément à plusieurs termes taxinomiques si on le désire (ainsi une brève sur une médaille d’or française aux Jeux olympiques peut être rattachée à la fois à « Sport » et à « France », comme l’indique le schéma ci-contre). Le concepteur ou l’administrateur ne sont donc pas obligés d’insérer leurs contenus dans une hiérarchie initiale unique. Il faut simplement que les taxinomies restent cohérentes (A ne peut pas dépendre de B dans l’une pendant que c’est B qui dépend de A dans une autre, ce qui n’aurait de toute façon aucun sens).

À sa création, un nœud se voit attribuer un node ID (NID) qui le caractérise. Au fur et à mesure de ses révisions, s’il y en a, le système incrémentera un compteur de revision ID (VID). Le concepteur peut choisir de conserver ou non les révisions autres que la plus récente. Chaque nœud possède aussi un titre, ce qui permet aux administrateurs de les gérer de façon plus commode.

Le système de révisions successives permet de revenir à une version antérieure si besoin, comme on le fait dans les wikis.

Traitement : modules (PHP)
Les traitements sont assurés par des modules, indépendants, juxtaposables, et combinables (un module peut utiliser les services fournis par un autre, et l’avoir comme prérequis). Ils sont activables et désactivables à volonté sans arrêter le site.

Présentation : thèmes (CSS et PHP)

Ni les nœuds ni les modules ne s’occupent de la présentation (ni même d’ailleurs les balises XHTML). Ce sont les styles qui en sont chargés, à la manière des feuilles de style en (X)HTML. Un administrateur de site Drupal peut changer profondément le style de celui-ci en quelques clics de souris, pour une commémoration ou un autre événement, par exemple.

Ce système est conçu pour bien séparer le cœur de métier d’un créateur de site (gestion et articulation des données) de la partie uniquement visuelle, qui fait appel à des concepts bien distincts (ergonomie entre autres) et peut avoir avantage à être sous-traitée à une officine spécialisée (agence web, graphiste indépendant).

Il est géré partout où cela est possible par des entrées dans une feuille de style CSS et, là où du traitement spécifique est nécessaire (par exemple alterner deux couleurs de fond pour présenter les lignes successives d’un tableau) par des fonctions de thémage simples écrites en PHP.

Les fonctions de thémage prennent en entrée des chaînes, vecteurs ou tableaux (ou tableaux de tableaux) et produisent en retour une chaîne XHTML de mise en forme qui sera dirigée par le programmeur vers la zone de son choix, désignée par son nom et non par sa position. Le concepteur et l’administrateur du site décident en dernier ressort des endroits de la page où s’afficheront ces informations, ainsi que la couleur et la police, et cela soit par réorganisation de blocs au tableau de bord, soit par modification des feuilles définissant le style de chaque bloc.

Si l’on ne désire modifier que les polices, leurs corps, leurs graisses et leurs couleurs, le module Sweaver permet aussi de le faire dynamiquement à même le site.

Administration des blocs

À un module de bloc sont associées des informations définies et modifiables extérieurement au module par l’administrateur :

  • une information de placement (haut, bas, droite, gauche…),
  • une information de priorité (en général de -10 à +10) par rapport aux autres blocs ayant la même indication de placement,
  • et une information indiquant si ce bloc est activé (=doit être affiché) ou pas.

Cette composition est voisine de la box strategy définie par Donald Knuth pour rendre cohérente la composition d’ouvrages en PAO

Depuis la version 6, les informations de priorité sont gérables par simple glisser/déplacer sur un menu spécial, ce qui facilite les réarrangements fréquents.

À partir de la version 7, il n’y a plus de blocs latéraux opposés à une partie centrale, mais uniquement des régions gérées sur un pied d’égalité par l’administrateur. Ainsi une fenêtre de débogage latérale peut être déplacée d’un clic dans la partie centrale plus vaste le temps d’un développement, etc.

Auteur: Wikipedia
URL: https://fr.wikipedia.org/wiki/Drupal
Licence: CC BY-SA 3.0

Laisser un commentaire

Votre adresse e-mail ne sera pas publiée. Les champs obligatoires sont indiqués avec *