Contributions open-source au projet JHipster

Encadrant : Didier Donsez.

Ce projet propose de développer plusieurs contributions au projet open-source JHipster

Liste non exhaustive et non priorisée des extensions (au générateur et à JDL) à développer et à contribuer auprès de la communauté (via le marketplace).
 * Bug fixes à puisser dans https://github.com/jhipster/generator-jhipster/issues
 * Clé primaire applicative (par défaut, le générateur d'entité génère un champ Id qui est la clé primaire)
 * intégration de nouveaux types de données et des composants Angular 4 idoines
 * geoloc, altitude
 * Séries temporelles TSBD
 * Graphes (http://projects.spring.io/spring-data-neo4j/)
 * Images (stockage File System, stockage BLOB du backend BD, stockage CDN, ...).
 * Ajout de nouveaux backends BD
 * OpenTSDB, InfluxDB
 * DBaaS (InfluxData, OVH Metrics) ...
 * Graphes (http://projects.spring.io/spring-data-neo4j/)
 * Composants d'UI pour les champs : badges pour les types boolean et enum, toogle-slide pour les checkboxs, angular-material, Leaflet, charts (statiques, temps réel) ...)
 * readonly fields
 * final fields : (certains champs ne doivent plus être modifiables après l'instanciation du bean).
 * field visibility (public, group, private) : (certains champs doivent être visibles soit de tous les utilisateurs, soit de tous les utilisateurs authentifiés, des utilisateurs appartenant à un groupe ou bien seulement de l'utilisateur (ie créateur).
 * Ajout des champs createdBy, lastModifiedBy, createrAt, lastModifiedAt (voir l'entité User) à une entité générée.
 * QueryService
 * userId fields
 * extra user-profile
 * Adresses
 * Réseaux sociaux
 * Sports
 * Forme (ie pour le sport)
 * amélioration du volet Swagger (OpenAPI2.0 et OpenAPI3.0)
 * Annotations supplémentaires
 * Géneration d'un frontend Apache Cordova (incluant une Leaflet pour les Entity ayant des types "Position").
 * Multi-thèmes Dashboard
 * SBAdmin 2
 * Gentella
 * Ngx-Admin (lien), Nebulla (lien)
 * Intégration d'un backend CMS.
 * Gestion de Content Delivery Network.
 * Intégration du protocole pub-sub MQTT.
 * Intégration du protocole pub-sub AMQP.
 * gestionnaire centralisé des Users et de leurs profiles (pour plusieurs microservices)
 * gestion du RateLimit (IP origin, GeoIPing, per user) par type d'opération (GET, PUT, POST, DELETE).
 * Resilience4j
 * Génération du Dockerfile pour les instances de container pour HAProxy (gestion de SSL-Termination, DDoS, ...).
 * Génération du Dockerfile pour les instances de container pour Nginx.
 * Gestion de quota sur les créations d'entité.
 * Intégration de chatbots open-source (Rasa.ai par exemple) ou commerciaux.
 * Intégration de la traduction automatique des messages et des contenus des champs texte
 * Ajout de l'import en bulk d'un entity (voir Spring Batch) par upload de fichiers CSV/XLS (génération du backend et du frontend).
 * Ajout de Captcha à la création de compte, au login, ... (ReCaptcha, ...)
 * Ajout d'autres réseaux sociaux (Linkedin, Github, ...)
 * Ajout de composants de paiement (Paypal, Cartes de crédit, ...)
 * Ajout de Telegraf, Hawkular aux dockerfiles générés des containers.
 * Voir http://www.hawkular.org/blog/2017/06/9/opentracing-spring-boot.html
 * Ajout d'un dockerfile pour Grafana configuré avec un dashboard taillé pour JHipster et les entités générées.
 * Intégration de Mockito
 * Intégration Websocket (lien)
 * Génération des fonctions pour un backend OpenWhisk (containers Docker) ou pour IBM Bluemix OpenWhisk.
 * Génération du backend pour Play : voir le code généré par Swagger Codegen pour Play et https://github.com/peterszatmary/learning-play-framework/wiki/Mysql,-JPA-and-Play!., https://github.com/playframework/play-java-rest-api-example
 * Intégration (sécurisée) de l'API Health Check http://microservices.io/patterns/observability/health-check-api.html
 * Ajout de HATEOS (exemple)
 * Ajout de Apache Phoenix à JHipster (JPARepository for Phoenix)
 * Ajout de Vitess à JHipster (JPARepository)
 * Ajout de Memcached à JHipster
 * Bloquage des authentifications répétées en échec (brute force) avec Fail2ban. (lien
 * Banissement des adresses IP au moyen de FreeGeoIP (Dockerfile)
 * Intégration de ElastAlert
 * Intégration de Intel Clear Containers
 * Intégration de Tags "user-defined" sur des entités (ajout/retrait/recherche par groupe de tags, liste de tags par défaut).
 * Intégration des API Slack. Faire une petite démo.
 * Ajout de test avec Spock (lien)
 * Authentification par One-Time Password
 * lien
 * Google Anthenticator
 * 2Factor Authentication
 * lien
 * Google Anthenticator
 * 2Factor Authentication

Une application de démo sera proposée en exemple. Par exemple, un gestionnaire de course sportive (voir groupe UltraTeam).