Voici comment créer une table dans une base de donnée autre que celle par défaut.
Code à mettre dans votre MODULE.install
Le principe : création d'un « HOOK_schema fake » et utilisation des HOOK_install et HOOK_uninstall pour créer / supprimer cette table en sélectionnant la bonne base.
Le code est pour drupal 8 mais il peut facilement être adapté pour drupal 7.
Quand on fait de l'intégration de thème sur Drupal 8, il est indispensable d'activer de debug Twig, le souci, c'est que parfois, on voudrait désactiver les suggestions pour par exemple, tester une condition.
C'est bientôt Noël et la littérature traitant de Drupal en Français est encore trop rare, alors pourquoi ne pas soutenir l'initiative de Frédéric Simonet en mettant sous le sapin son livre "WordPress, Joomla, Drupal : Comprendre avant de s'engager" ?
Formateur depuis 2007 dans le domaine de la gestion de de contenu, Frédéric a écrit cet ouvrage qui permet de se faire une idée assez juste des forces et faiblesses des 3 CMS open source qui tiennent le haut du pavé en nombre de plateformes déployées.
Après une présentation générale des 3 outils, la première partie propose analyse systématique et détaillée de leurs performances sur des critères tels que l'édition des contenus, l'optimisation du référencement ou encore la sécurité. Elle se poursuit par un comparatif des coûts d'intégrations, basé sur un découpage très intéressant et précis en micro-tâches nécessaires à la mise en place d'un site web.
La seconde partie, la plus conséquente, décrit en détail les micro-tâches en question et vous permettra de réaliser un premier site après avoir décrit comment s'organise un projet web. Cette partie est très détaillée et prend le parti d'être didactique, mais ne fera pas du lecteur un expert dans les 3 technologies (on regrettera, par exemple, l'absence du module Pahtauto sur Drupal).
La lecture de "WordPress, Joomla, Drupal : Comprendre avant de s'engager" vous donnera une excellente vision des capacités des 3 outils. Attention cependant, en ce qui concerne Drupal, c'est la version 7 qui est détaillée dans la partie pratique et tout ce qui y est dit n'est plus toujours vrai dans Drupal 8 (plus besoin d'installer un module Wysiwyg, par exemple). Il semble également dommage d'être resté essentiellement sur des considérations techniques et fonctionnelles, et de ne pas avoir comparé d'avantage les écosystèmes (contributeurs, intégrateurs) qui font vivre ces logiciels open source.
Ces réserves n'enlèvent rien à la qualité d'un comparatif qui convient parfaitement à un lecteur qui souhaite choisir le bon outil pour créer lui-même son site.
Drupal commerce 2 permet désormais nativement de gérer les différentes taxes et TVA à appliquer sur une boutique en ligne, quelque soit son pays et leurs règles respectives en cette matière. La plupart des modules contribués permettant de gérer ces éléments sur Commerce 1.x ne sont donc plus nécessaires. Découvrons comment utiliser le concept des Resolver de Drupal commerce 2.x pour définir le taux de TVA à appliquer sur différents produits.
Ça vient à contresens du paradigme des noeuds, mais parfois on souhaite que les pages de détail d'un noeud d'un type de contenu en particulier ne soient pas accessible.
Avec quelques adaptation, ceci peut aussi fonctionner pour les pages de terme de taxonomie.
Voici comment faire :
1ère étape, déclarer un services dans mon_module.services.yml
2ème étape, créer l'event subscriber: src/EventSubscriber/NodeCPRedirect.php dans le dossier de mon module.
Ici je vais chercher à rediriger tous les noeuds de type « communiques_de_presse » vers la vue « view.front_communiques_de_presse.page », mais cela peut-être évidement n'importe quelle route.
namespace Drupal\mon_module\EventSubscriber;
use Drupal\Core\Url;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\HttpFoundation\RedirectResponse;
use Symfony\Component\HttpKernel\Event\GetResponseEvent;
use Symfony\Component\HttpKernel\KernelEvents;
class NodeCPRedirect implements EventSubscriberInterface {
Parfois on a pas le choix et l'on est obligé de passer par PHPMyAdmin pour récupérer un export de base de données.
Avec un dump de Drupal 8, lors de l'import, on peut tomber sur l'erreur suivante :
Requête SQL :
CREATE TABLE IF NOT EXISTS `key_value` ( `collection` varchar(128) CHARACTER SET ascii NOT NULL DEFAULT '' COMMENT 'A named collection of key and value pairs.' `value` longblob NOT NULL COMMENT 'The value.', PRIMARY KEY (`collection`,`name`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Generic key-value storage table. See the state system for'
MySQL a répondu:
#1064 - Erreur de syntaxe près de '`value` longblob NOT NULL COMMENT 'The value.',
PRIMARY KEY (`collection`,`nam' à la ligne 3
C'est visiblement du à un bug dans une certaine version de PHPMyAdmin.
Il est possible de corriger cette erreur en modifiant manuellement le dump en deux étapes.
La première, remplacez le bloc suivant :
CREATE TABLE IF NOT EXISTS `key_value` (
`collection` varchar(128) CHARACTER SET ascii NOT NULLDEFAULT'' COMMENT 'A named collection of key and value pairs.'
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Generic key-value storage table. See the state system for';
par
CREATE TABLE IF NOT EXISTS `key_value` (
`collection` varchar(128) CHARACTER SET ascii NOT NULLDEFAULT'' COMMENT 'A named collection of key and value pairs.',
`name` varchar(128) CHARACTER SET ascii NOT NULLDEFAULT'' COMMENT 'The key of the key-value pair. As key is a SQL reserved keyword, name was chosen instead.',
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Generic key-value storage table. See the state system for';
Seconde étape, supprimez le bloc suivant :
ALTER TABLE `key_value`
ADD `name` varchar(128) CHARACTER SET ascii NOT NULLDEFAULT'' COMMENT 'The key of the key-value pair. As KEY is a SQL reserved keyword, name was chosen instead.';
Une fois cela fait, vous pourrez alors importer le dump sans soucis.
Drupal Commerce 2.x - Adjustments: L'ajustement de prix
Avec Drupal Commerce 2.x arrive une nouvelle notion: les Adjustments.
Qu'est ce que l'adjustment ?
L'adjustment, ou ajustement en français, permet de modifier le montant d'une ligne de commande ou d'une commande, que ce soit en le diminuant ou en le réduisant.
Deux exemples d'ajustements tarifaire intégrés au fonctionnement du core:
Drupal Commerce 2.x - Rendre un prix dynamique ou calculé via un service tiers
Dans le cas d'un commerce BtoB ou métier, les règles de prix sont souvent plus compliquées qu'un simple prix par produit. Dans ce cas, deux choix possibles:
Le métier est dans un outil (CRM ou autre) externe.
Le métier et donc la règle de calcul doit être gérée par le site.
Dans les 2 cas, Drupal Commerce 2.x offre les mécanismes pour facilement intégrer ces règles métier pour définir le prix unitaire de notre produit.
Open Source Summit est la fusion de 2 événements (Solutions linux et l'Open world forum) et se déroulera le 6 et 7 décembre 2017 au DOCK PULLMANN à La Plaine St-Denis (Paris)
Ces 2 anciens événements, l'association Drupal France et Francophonie (DrupalFR) était présent et c'est dans la logique que nous serons présent.
Ce rendez-vous se découpe de différentes manières, avec des conférences, des ateliers, et une partie exposition. Le dernier espace sera coupé en 2 parties avec une partie professionnel et une autre partie village associatif.
Stand :
L'Association Drupal France et Francophonie (DRUPALFR) sera dans la partie village associatif et recherche des bonnes volontés pour venir nous aider à tenir le stand pour parler de Drupal et aussi venir nous voir.
Si vous souhaitez venir nous rendre visite, vous serez les bienvenus sur le stand A31.
Si vous voulez tenir le stand avec moi, nous mettons à disposition un Doodle si vous souhaitez venir nous aider (par demi journée)
Nous avons vu dans un précédent billet comment mettre en place un processus de publication sur Drupal 8 avec les modules Content moderation et Workflows. Nous allons aborder ici une problématique similaire mais en s'appuyant cette fois sur le module State machine, module qui va nous permettre de mettre en place un ou plusieurs processus métier sur n'importe quelle entité de Drupal.
Les nouveautés de Drupal 8.4.0 admin jeu 16/11/2017 - 10:53
Toujours dans les temps, la nouvelle version mineure de Drupal, 8.4.0, est disponible depuis le 4 octobre 2017. Pour la première fois depuis deux ans, cette mise à jour contient des éléments qui pourront casser la rétrocompatibilité de certains sites.
Corps
Toujours dans les temps, la nouvelle version mineure de Drupal, 8.4.0, est disponible depuis le 4 octobre 2017. Pour la première fois depuis deux ans, cette mise à jour contient des éléments qui pourront casser la rétrocompatibilité de certains sites. Comme pour la sortie des précédentes versions mineures de Drupal, et notamment la mise à jour vers Drupal 8.3.0, cet article vous dévoilera les détails des changements apportés ces six derniers mois.
Attention à la rétro-compatibilité des dépendances (librairies) !
La technologie progresse et l'équipe de maintenance du cœur doit faire des choix pour concentrer les efforts de la communauté sur des tâches à valeur ajoutée pour l'avenir. Parfois, il s'agit simplement de faire des arbitrages entre des fonctionnalités fondamentales pour l'avenir et la compatibilité avec des choix ou projets passés. Pour la première fois depuis la sortie de Drupal 8, cette version mineure introduit des changements qui pourraient poser des problèmes de compatibilité avec certains projets existants. Il est donc demandé à toutes les personnes en charge de la maintenance d'un site Drupal 8 d'être extrêmement vigilantes lors du passage à la 8.4.
Arrêt du support de Internet Explorer 9 et 10
Depuis avril 2017 Microsoft a arrêté le support de Internet Explorer 9 et 10. Ces vielles versions ont longtemps été la plaie des intégrateurs et, pour un outil comme Drupal, leur support représentait un coût assez important alors que le nombre d'utilisateurs concernés ne cessait de baisser. Officiellement, à partir de la 8.4.0, ces versions ne sont donc plus supportées. Cela signifie que les sites continueront de fonctionner comme précédemment mais qu'aucun effort supplémentaire ne sera alloué à cette compatibilité à l'avenir. Les hacks en place pour faire fonctionner certaines choses pour ces versions seront progressivement retirés à partir de Drupal 8.5.
Mise à jour majeure de Symfony et jQuery
Que vous soyez plutôt back ou front, pas de répit avec cette nouvelle version ! Symfony passe à la version 3.2.8+ (au lieu de 2.8+) et jQuery à la version 3.2.1 (au lieu de 2.2.4). Bien que ces deux versions aient une forte compatibilité descendante, si certaines de vos fonctionnalités s'appuient sur des fonctions dépréciées, elles cesseront probablement de fonctionner lors de la mise à jour. Cela a été le cas pour nous sur le menu déroulant d'un projet, par exemple.
Du fait des divers changements dans les dépendances et dans la façon dont le cœur gère quelques services, Drush 8.1.14 et inférieur n'est pas compatible avec Drupal 8.4.0 et supérieurs. Si votre Drush est installé localement au projet (il devrait), un simple composer update devrait résoudre le problème. Dans le cas contraire, référez vous à la documentation officielle.
Attention, indépendamment de l'évolution du cœur de Drupal, Drush évolue également vers une nouvelle version majeure, Drush 9. Cette dernière est une réécriture complète de Drush et apporte son lot de nouveautés très intéressantes (on en parlera dans un autre article). Cependant, si vous avez des commandes drush personnalisées, des alias de sites ou des scripts qui utilisent cet outil de façon intensive, prenez votre temps pour monter de version car vous aurez un peu de travail pour adapter votre usage.
Ça bouge chez les expérimentaux !
Si vous avez suivi un peu nos articles concernant les nouveautés de Drupal 8, vous saurez déjà que les versions mineures sont l'occasion d'introduire de nouvelles fonctionnalités sous la forme de modules expérimentaux. Pour la version 8.4, nul nouveau module expérimental mais de nombreux changements.
Les modules Datetime Range, Inline Form Errors, Layout Discovery, Media et Workflows, sont désormais considérés comme stables et plus expérimentaux.
Media, n'est qu'un support pour les modules contribués et ne propose aucune fonctionnalité de lui même. Il est caché dans l'interface de gestion des modules pour éviter les confusions mais sera automatiquement activé en cas de besoin. Si vous utilisiez le module contribué Media Entity avec la précédente version de Drupal, sa version 2.0 contient un chemin de migration obligatoire pour transiter vers le module du cœur.
Workflows, en passant en version stable, a procédé à quelques derniers changements de fond. Selon votre usage du module (surtout si vous l'utilisez autrement qu'avec Content Moderation), vous devriez consulter le rapport de changement associé pour adapter votre code au nouveau fonctionnement. Si vous utilisez Content Moderation, qui a lui aussi subi son lot d'évolutions, vous devriez jeter un œil à son chemin de mise à jour non officiel qui vous permettra de continuer à vous en servir sans altérer vos données.
Migrate, Migrate Drupal et Migrate Drupal UI continuent leur progression vers le support complet d'un chemin de migration de Drupal 6 ou 7 vers Drupal 8. Par exemple, les champs date et node_reference de Drupal 6 pourront désormais être migrés vers Drupal.
Field Layout, dont nous avons détaillé le fonctionnement lors de la précédente mise à jour, a vu quelques corrections de bug mais pas de changement fondamental. Malgré son intérêt fonctionnel, il ne lui reste plus que quelques mois de période probatoire avant d'être éjecté du cœur pour retourner dans le mode des modules contribués.
Settings Tray et Place Blocks continuent leur progression. Le premier s'offre une version beta et pourrait donc accéder à la stabilité à la prochaine version mineure. Le second, lui, va progressivement disparaître pour être absorbé dans le module Block du cœur lors du passage à la 8.5 si tout se déroule comme prévu.
Évolutions de l'interface
Suite à des tests d'utilisabilité auprès d'un large panel d'utilisateurs finaux, il est apparu que le bouton déroulant était trop déroutant. La décision a donc été prise de revenir à un bouton simple doublé d'une case à cocher pour gérer la publication. Dans le cas de l'utilisation du module Workflows, la case à cocher est remplacée par le widget de gestion des états.
Autre amélioration plus mineure : le choix du fuseau horaire dans le compte utilisateur se fait désormais via un menu déroulant groupé par continent et classé par ordre alphabétique (au lieu du classement par décalage horaire qui était utilisé auparavant).
Amélioration des performances
Afin d'adresser des problèmes de tables de cache grossissant jusqu'à atteindre plusieurs Gigas sur certains projets, une option a été ajoutée pour pouvoir poser une limite, par entrepôt de cache, au nombre d'enregistrements pouvant coexister. Cette limite, fixée par défaut à 5000 entrées, peut être ajustée en fonction des besoins du projet très facilement. Par exemple :