{"id":46061814,"url":"https://github.com/abes-esr/abes-hello-back","last_synced_at":"2026-03-01T11:31:35.488Z","repository":{"id":37923522,"uuid":"309442294","full_name":"abes-esr/abes-hello-back","owner":"abes-esr","description":"Application exemple type \"Hello World\" qui illustre la politique de développement de l'Abes avec des modèles pour la partie back : API et batch.","archived":false,"fork":false,"pushed_at":"2026-02-16T10:59:13.000Z","size":19403,"stargazers_count":2,"open_issues_count":1,"forks_count":0,"subscribers_count":6,"default_branch":"develop","last_synced_at":"2026-02-16T19:03:14.472Z","etag":null,"topics":["docker","hello-world","poldev","spring"],"latest_commit_sha":null,"homepage":"","language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"other","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/abes-esr.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2020-11-02T17:17:59.000Z","updated_at":"2026-02-16T10:59:17.000Z","dependencies_parsed_at":"2024-02-29T16:31:44.042Z","dependency_job_id":"4637208b-b4be-4954-8982-9d68ab27bf0c","html_url":"https://github.com/abes-esr/abes-hello-back","commit_stats":null,"previous_names":[],"tags_count":30,"template":false,"template_full_name":null,"purl":"pkg:github/abes-esr/abes-hello-back","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/abes-esr%2Fabes-hello-back","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/abes-esr%2Fabes-hello-back/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/abes-esr%2Fabes-hello-back/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/abes-esr%2Fabes-hello-back/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/abes-esr","download_url":"https://codeload.github.com/abes-esr/abes-hello-back/tar.gz/refs/heads/develop","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/abes-esr%2Fabes-hello-back/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":29968452,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-03-01T10:55:55.490Z","status":"ssl_error","status_checked_at":"2026-03-01T10:55:55.175Z","response_time":124,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["docker","hello-world","poldev","spring"],"created_at":"2026-03-01T11:31:34.898Z","updated_at":"2026-03-01T11:31:35.480Z","avatar_url":"https://github.com/abes-esr.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"# abes-hello-back\n\n[![build-test-pubtodockerhub](https://github.com/abes-esr/abes-hello-back/actions/workflows/build-test-pubtodockerhub.yml/badge.svg)](https://github.com/abes-esr/abes-hello-back/actions/workflows/build-test-pubtodockerhub.yml) [![Docker Pulls](https://img.shields.io/docker/pulls/abesesr/abes-hello.svg)](https://hub.docker.com/r/abesesr/abes-hello/)\n\nApplication backend à trois modules (Core, Web et Batch) qui illustre la politique de développement de l'Abes pour une API Web RESTful. L'application front se trouve sur le dépôt suivant : [Github abes-hello-front](https://github.com/abes-esr/abes-hello-front)\n\nLes fonctionnalités misent en œuvre dans ``abes-hello-back`` sont :\n1. Un service web RESTful permettant d'obtenir un message public pour tous les utilisateurs\n2. Un service web RESTful permettant aux utilisateurs authentifiés sur le service de recevoir un message privé et de consulter l'historique des commandes passées\n3. Un batch permettant de lire des données en base de données puis d'effectuer un traitement dessus \n\nVersion: 2.0.1-SNAPSHOT\n\n## Développements\n\n### Module Core\n\n### Module web (l'API)\n\n### Module batch\n\nSpringBatch de base qui illustre l'utilisation d'une tasklet et d'un chunk.\nLa tasklet lit un fichier texte et place son contenu dans une variable.\nLa variable est passée au chunk gràce à l'ExecutionContext (accessible dans les Tasklet et les classes du chunk en implémentant l'interface StepExecutionListener).\nLe chunk est composé de 3 parties, reader, processor et writer.\nIl est configuré pour traiter les données par paquet de 10.\nLe processor fait appel à une méthode externe qui illustre l'utilisation du retry (on peut le configurer via l'annotation @Retry, elle permet d'essayer plusieurs fois un traitement qui est susceptible de renvoyer une erreur (par exemple un appel à un service web ou une connexion à une base de données).\n\nConfiguration du lancement du batch en local avec IntelliJ :\n\nAvec IntelIJ : \n- Ajouter la variable : `spring.batch.job.name=jobTraitement` dans la configuration du lancement du batch `Environnment variables`   \n- Si nécessaire, ajouter les variables `fr.abes.helloabes.batch.*` et/ou `fr.abes.helloabes.batch.BatchConfiguration` dans la configuration du lancement du batch `Code Coverage`\n\n### Utilisation en local avec Docker\n\nDémarrer l'application abes-hello-back sur votre poste local à l'aide du fichier Dockerfile situé à la racine du projet. \nPour se faire, configurez d'abord votre IDE de manière à inclure cette option de démarrage (`run option` avec IntelIJ) : `-p 8081:8081`\n\nPour démarrer l'ensemble de l'application abes-hello sur votre poste local, voir le dépôt Github [Github abes-hello-docker](https://github.com/abes-esr/abes-hello-docker) qui propose les configurations docker de l'ensemble de l'API Web RESTful Abes-Hello pour déployer en local ou sur des env de dev, test ou prod.\n\n### Publier une nouvelle release de l'application\n\nSe référer au chapitre `publier-une-nouvelle-release-dune-application` de la [politique informatique de l'Abes](https://politique-informatique.abes.fr/docs/dev/development/source-code/#publier-une-nouvelle-release-dune-application)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fabes-esr%2Fabes-hello-back","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fabes-esr%2Fabes-hello-back","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fabes-esr%2Fabes-hello-back/lists"}