jHipster : le générateur de projet pour hipsters

Pourquoi un générateur de projet ?

Sur tous les projets techniques, notamment les applications web, les mêmes problématiques reviennent toujours. Comme la gestion des entités, la création des requêtes CRUD (Create, Read, Update, Delete) pour chaque entité, la gestion des comptes et de rôles, ou encore le développement d’une partie administration par exemple.

Toutes ces mêmes problématiques ont un coût en développement non négligeable et ne font pas partie des problématiques liées au métier de l’application.

Les générateurs de projets ont pour but d’alléger le temps passé sur le développement de ces types de problématiques récurrentes. Ils vont pouvoir générer automatiquement les parties non spécifiques au métier, qui n’apportent pas de valeur ajoutée à l’application développée.

Développés par des communautés compétentes et souvent en open-source, les générateurs de projets apportent aussi un cadre au projet en développement avec l’apport de normes et de standards.


Le projet jHipster

Jhipster Logo

Java Hipster ou jHipster est un projet open-source qui permet de générer une application web complète avec une partie back-end en Java / Spring-Boot et une partie front-end avec la techno de son choix parmi :

Le principe de jHipster est relativement simple. Vous définissez un schéma d’entités (leurs définitions + leurs relations) et à partir de ce schéma, jHipster va pouvoir générer :

Le projet rassemble aujourd’hui plus de 15 700 stars sur Github. Il est utilisé par de nombreux grands groupes comme HBO, HSBC, Bosch, Carrefour, Adobe, Ippon, voire même Google.


Générer son premier projet jHipster !

Pour générer un projet jHipster, vous avez deux options principales :

La première option est plutôt recommandée lorsque vous débutez avec jHipster et que vous voulez vous faire une idée de son potentiel.

Si vous voulez plutôt passer par l’outil en ligne de commande vous pouvez utiliser npm pour installer le CLI :

npm install -g generator-jhipster

Voici les différentes étapes pour générer un projet jHipster via le CLI :

Commencez par créer un dossier pour votre projet jHipster :

mkdir jhipsterDemoApp && cd jhipsterDemoApp

Lancez la commande : jhipster

Commande jhipster

Le CLI de jHipster se lance et vous demande quel type d’application vous voulez générer. Ici nous allons sélectionner “Monolithic application”. C’est-à-dire que nous aurons une seule application avec un serveur unique pour l’ensemble des opérations à réaliser.

Les autres options concernent les micro-services. Lorsque vous commencez un projet, une architecture en micro-services est rarement nécessaire. Elle trouve plutôt son utilité lorsqu’une application doit supporter un grand nombre de requêtes à traiter, lorsqu’il y a déjà plusieurs milliers d’utilisateurs au moins.

Jhipster Name Application

Le CLI demande ensuite le nom de l’application à générer, vous pouvez laisser par défaut le nom du dossier créé. Choisissez aussi le nom de package pour la partie back-end.

Choose default Java package

Vous pouvez choisir d’utiliser ou non le jHipster registry qui vous permettra d’accéder à différentes statistiques et données sur votre application.

Jhipster registry
Technology Choice

jHipster est capable de gérer différents types de bases de données : les bases classiques de type SQL, mais aussi les bases No-SQL comme MongoDB. On sélectionne ici le type SQL.

Database Choice

jHipster va alors demander les types à utiliser en développement et en production. Pour le développement, le type H2 avec persistance sur le disque est très pratique. Il permet aux développeurs du projet de ne pas avoir à configurer eux-mêmes une base de données pour travailler sur le projet.

Production Database Choice
Dev Database Choice

Vous pouvez choisir d’utiliser un système de cache supplémentaire sur la base de données.

Cache choice

Si vous le souhaitez, vous pouvez rajouter des options spécifiques à votre projet jHipster, comme la recherche avec Elasticsearch.

Supplementary Tech Choice

Maintenant pour la partie front-end du projet, vous avez le choix entre Angular et React. Pour avoir VueJS il faudra passer par ce blueprint.

On sélectionne par exemple ici React.

Front-End Options

Vous pouvez aussi choisir un thème Bootstrap par défaut pour votre projet.

Bootstrap Theme

Vous avez le choix d’intégrer ou non un système de traduction et de sélectionner les différentes langues à supporter.

Intertionalize Support
Native Language Choice

Enfin le CLI vous demande si vous voulez rajouter un outil pour les tests unitaires ou utiliser un module présent dans le jHipster marketplace. On ne va rien ajouter ici pour notre génération.

Unit Test Choice
Other Jhuipster Generators

On valide et ensuite jHipster génère le projet dans le dossier courant. Il va générer tous les fichiers nécessaires au bon fonctionnement du back-end et du front-end.

Confirmation message

On retrouve ensuite dans le projet généré, 2 sous-projets, 1 pour le back-end en Java avec le framework Spring-Boot et 1 pour le front-end avec des fichiers TypeScript et la librairie React Js.

Structure d'un projet Jhipster

Lançons maintenant le projet en mode développement :

Pour lancer le serveur back :

./mvnw

Pour lancer la partie front-end :

yarn && yarn start

Et voilà vous avez généré et lancé votre premier projet jHipster ! 🎉🎉🎉

Vous pouvez vous connecter en tant qu’administrateur sur la plateforme (admin / admin) et découvrir les écrans générés par jHipster.


Gérer son schéma d’entités avec le JDL Studio

Voyons maintenant comment importer un schéma d’entités dans un projet jHipster.

jHipster propose un outil en ligne nommé JDL Studio particulièrement utile et simple d’utilisation.

Cet outil va vous permettre de déclarer vos différentes entités ainsi que les relations entres elles via une syntaxe assez simple.

Vous pouvez ensuite exporter ce schéma dans un fichier via l’outil.

Ce même fichier peut ensuite être importé dans votre projet via cette ligne de commande :

jhipster import-jdl jhipster-jdl.jh

jHipster va alors vouloir écraser certains fichiers, vous pouvez répondre oui à chaque fois parce que c’est la première génération d’entités dans votre projet.

Et voilà vos entités vont être créées dans votre projet et vous allez pouvoir les gérer depuis l’administration.


Quelques bonnes pratiques

Comme vous l’avez vu, jHipster vous a généré pas mal de fichiers pour chacune de vos entités. Dans le back-end, pour chaque entité, on retrouvera par exemple :

A chaque fois que l’on veut mettre à jour une entité, jHipster va regénérer les fichiers liés à celle-ci. Pour éviter les conflits sur ces fichiers, il est nécessaire de ne pas les utiliser pour la logique propre à son application. Pour cela, une méthode que nous utilisons au BearStudio est d’étendre les fichiers générés par jHipster.

Ainsi, si l’on veut ajouter un nouveau endpoint accessible dans l’API par exemple pour l’entité “Location” on va créer ces 3 fichiers :

De ce fait, lorsqu’on modifiera l’entité Location, il n’y aura pas de conflits avec la re-génération de jHipster sur ces fichiers.


Mettre à jour une entité

Pour mettre à jour une entité avec jHipster il vous suffit de modifier votre schéma d’entités précédemment créé via le JDL Studio et de le réimporter. Vous pouvez aussi modifier l’entité via le CLI avec la commande suivante :

jhispter entity NomEntité

Entity Update

jHipster vous demande si vous voulez simplement regénérer les fichiers liés à l’entité, ou ajouter / supprimer des champs et relations à votre entité.

Une fois votre choix fait et vos modifications appliquées, le générateur va modifier tous les fichiers liés à votre entité et il vous demandera votre autorisation pour cela. Vérifiez bien pour chaque fichier que les modifications proposées par jHipster ne vont pas impacter votre propre logique. C’est pour cela qu’il vaut mieux étendre et ne pas modifier les fichiers de bases générés par jHipster.

Mise à jour de la base de données avec Liquibase

Lorsque vous mettez à jour une entité, jHipster va vouloir mettre à jour la table liée à cette entité en proposant une modification des fichiers Liquibase gérant cette table.

Mais c’est quoi Liquibase ?

Liquidbase

Liquibase est une bibliothèque permettant de versionner et d’appliquer des changements dans un schéma de base de données.

jHipster utilise ainsi Liquibase pour gérer les tables liées aux entités du projet.

Les fichiers liés à Liquibase sont dans le dossier /src/main/resources/config/liquibase de votre projet.

Le fonctionnement de Liquibase avec jHipster est simple :

Lors de la génération initiale de vos entités, jHipster va créer les fichiers Liquibase (les changelogs) pour créer les tables correspondantes aux entités.

Et lorsque vous allez vouloir mettre à jour une entité, jHipster va proposer de modifier les fichiers Liquibase générés à la base. Or Liquibase est un outil pour versionner les changements sur les bases de données. Un peu à la manière de Git avec les commits, chaque changement devra se faire dans un nouveau changelog et il est impossible de modifier un changelog précédent. Liquibase lèvera une erreur si vous autorisez jHipster à modifier les fichiers Liquibase initiaux.

Pour ce point vous avez deux options possibles :

Si vous souhaitez ne pas avoir à vous occuper de cette partie, vous pouvez utiliser ce blueprint.

Aller plus loin

Pour supporter jHipster : https://opencollective.com/generator-jhipster

Guide d’utilisation : https://www.ionos.fr/digitalguide/sites-internet/developpement-web/jhipster/

« Etre productif avec jHipster » Julien Dubois, Devoxx France 2017 : https://www.youtube.com/watch?v=wJruVpv0WH4

Publié le 28/05/2020 dans Développement

Rédigé par :

              

Vous souhaitez éprouver votre produit ?

Demandez un mini audit UX gratuit