UNPKG

@gouvfr-anct/mednum

Version:

✨ Permet de transformer une source de données vers le schéma des lieux de mediation numerique

233 lines (152 loc) 10.7 kB
# Contribution ## Table des matières - 📦 [Prérequis](#prérequis) - 🚀 [Installation](#installation) - 🛠️ [Utilisation](#utilisation) - 🤝 [Contribution](#contribution) - 🏗️ [Construit avec](#construit-avec) ## Prérequis ### Outils - [Git](https://git-scm.com/) : Système de contrôle de versions distribué d'un ensemble de fichiers - [Node](https://nodejs.org/) : Environnement d'exécution pour Javascript - [Yarn](https://yarnpkg.com/) : Gestionnaire de paquets pour les produits développés dans des environnements Node > Node et Yarn peuvent être installés via [nvm](https://github.com/nvm-sh/nvm) qui permet d'obtenir et d'utiliser rapidement différentes versions de Node via la ligne de commande. ## Installation ### Mise en place des sources et des dépendances Cloner le dépôt en local ```bash git clone git@github.com:anct-cartographie-nationale/mednum-cli.git ``` Aller dans le dossier du projet pour installer les dépendances ```bash cd mednum-cli yarn ``` ### Installer Husky [Husky](https://typicode.github.io/husky) est un outil de gestion des hooks git pour effectuer des tâches automatiques ```bash yarn husky install ``` Rendre exécutable les fichiers qui contiennent les hooks : ```bash chmod a+x .husky/commit-msg chmod a+x .husky/pre-commit ``` ### Configurer l'environnement Le fichier d'environnement `.env` contient les variables d'environnements nécessaires à l'exécution de la commande `mednum publier` Pour faciliter la mise en place du fichier d'environnement, vous pouvez copier le fichier [.env.example](.env.example) et le renommer en `.env`. ⚠️ Le fichier `.env` est susceptible de contenir des données sensibles, il ne doit jamais être traqué par un gestionnaire de version. ⚠️ Le fichier `env.example` est une aide pour la mise en place du fichier `.env`, il est public et ne doit pas contenir de données sensibles. Configurez les variables d'environnements attendus dans le fichier `.env` : #### `DATA_GOUV_API_URL` L'URL de l'API data.gouv, il est recommandé d'utiliser l'API de démo pour le développement : https://demo.data.gouv.fr/api/1 #### `DATA_GOUV_API_KEY` La clé d'API qui permet à la commande d'effectuer des requêtes sur l'API nécessitant une authentification en votre nom. Pour obtenir une clé d'API, vous devez créer un compte sur [demo.data.gouv.fr](https://demo.data.gouv.fr/fr/). Une fois connecté, rendez-vous sur [votre profil dans le menuAdministration](https://demo.data.gouv.fr/fr/admin/me/). En bas à gauche de la page, vous trouverez un encart intitulé `Clé d'API`. Il vous suffit de copier la clé et de la coller comme valeur dans le fichier `.env` #### `DATA_GOUV_REFERENCE_TYPE` Il existe deux moyens de publier des jeux de donnés sur data.gouv ; vous pouvez le faire en votre propre nom ou au nom d'une organisation. Cette variable permet d'indiquer le type de publication : - La valeur `owner` signifie que vous publiez en votre propre nom. - La valeur `organization` signifie que vous publiez au nom d'une organisation. #### `DATA_GOUV_REFERENCE_ID` Vous devez indiquer l'identifiant de votre compte si vous avez choisi le type `owner` ou l'id de l'organisation si vous avez choisi le type `organization`. - Retrouvez l'id de votre compte en vous rendant sur la page d'[Administation](https://demo.data.gouv.fr/fr/admin/) de votre compte. - Appuyez sur la touche `F12` pour afficher l'inspecteur de votre navigateur et observez le moniteur de réseau - [Optionnel] Effacez les requêtes présentes pour faciliter l'identification des prochaines requêtes - Dans la liste à gauche, cliquez sur le menu `Profil` - Une requête avec le paramètre `?owner=` devrait apparaitre dans le moniteur de réseau, la valeur à la suite du `=` correspond à l'id de votre compte - Par exemple pour `.../api/1/harvest/sources/?owner=6396e6363a1ab130371ff777&deleted=true&lang=fr&_=1674118850001`, l'id est `6396e6363a1ab130371ff777` - Retrouvez l'id d'une organisation en vous rendant sur la page d'[Administation](https://demo.data.gouv.fr/fr/admin/) de votre compte. - Dans la liste à gauche, vos organisations s'affichent en dessous du menu `Profil`. - Cliquez sur l'organisation dnt vous voulez retrouver l'id. - Une fois la page administration de l'organisation, récupérer le dernier paramètre de l'URL de la page : il s'agit de l'id de l'organisation - Par exemple pour `.../admin/organization/4a4fc649a5a4982f465cfa24/`, l'id est `4a4fc649a5a4982f465cfa24` ## Utilisation Ces commandes servent dans un contexte de développement de l'application. ### Test Tester le projet : ```bash yarn test ``` ### Global lint Analyse statique de tous les fichiers `.ts` du projet : ```bash yarn lint.all ``` ### Staged lint Analyse statique des fichiers `.ts` qui ont été ajoutés avec la commande `git add` : ```bash yarn lint.staged ``` ### Commit lint Valider la syntaxe de l'ensemble des commits réalisés depuis la dernière version commune avec la branche `main` : ```bash yarn lint.commit ``` ### Prettier check Vérifier la syntaxe de l'ensemble des fichiers du projet : ```bash yarn prettier.check ``` ### Prettier Corriger la syntaxe de l'ensemble des fichiers du projet : ```bash yarn prettier ``` ### Build Générer une version prête à être publiée : ```bash yarn build ``` ## Contribution ### Nommage des branches - Avant de créer une nouvelle branche de travail, récupérer les dernières modifications disponibles sur la branche `main` - La nouvelle branche de travail doit ête préfixée par `build/`, `chore/`, `ci/`, `docs/`, `feat/`, `fix/`, `perf/`, `refactor/`, `revert/`, `style/` ou `test/` en fonction du type de modification prévu, pour plus de détails à ce sujet, consulter [Conventional Commits cheat sheet](https://kapeli.com/cheat_sheets/Conventional_Commits.docset/Contents/Resources/Documents/index) ### Commits #### Convention Les commits de ce repository doivent respecter la syntaxe décrite par la spécification des [Commits Conventionnels](https://www.conventionalcommits.org/fr) #### Signature La branche `main`, ainsi que l'ensemble des branches de travail avec un préfixe valide requièrent que les commits soient signés : - La documentation de GitHub indique comment [configurer la signature des commits](https://docs.github.com/en/enterprise-server@3.5/authentication/managing-commit-signature-verification/about-commit-signature-verification) - Les utilisateurs de [keybase](https://keybase.io/) peuvent [signer leurs commits avec leur clé GPG sur Keybase](https://stephenreescarter.net/signing-git-commits-with-a-keybase-gpg-key/) ## Construit avec ### langages & Frameworks - [TypeScript](https://www.typescriptlang.org/) est un langage open source construit à partir de JavaScript ### Outils #### CLI - [Vitest](https://vitest.dev/) est une boîte à outils pour écrire des tests automatisés en JavaScript - [Eslint](https://eslint.org/) est un analyseur statique de JavaScript - [Prettier](https://prettier.io/) est un magnificateur de code source en JavaScript - [Husky](https://typicode.github.io/husky/#/) est un outil qui permet d'effectuer des vérifications automatiques avant de publier des contributions. - [Commitlint](https://github.com/conventional-changelog/commitlint) est un outil de vérification des commits suivant le [format des Commits Conventionnels](https://www.conventionalcommits.org/fr/v1.0.0/). - [Lint-staged](https://github.com/okonet/lint-staged) est un outil qui permet d'effectuer un ensemble de vérifications à l'aide d'autres outils sur un ensemble de fichiers qui viennent d'être modifiés. #### CI/CD - [Github Actions](https://docs.github.com/en/actions) est l'outil d'intégration et de déploiement continu intégré à GitHub - L'historique des déploiements est disponible [sous l'onglet Actions](https://github.com/anct-cartographie-nationale/mednum-cli/actions/) - Secrets du dépôt : - `NODE_AUTH_TOKEN` : Clé d'accès NPM pour publier sur l'organisation [@gouvfr-anct](https://www.npmjs.com/org/gouvfr-anct) - Secrets de l'environnement `demo` : - [DATA_GOUV_API_URL](#DATA_GOUV_API_URL) - [DATA_GOUV_API_KEY](#DATA_GOUV_API_KEY) - [DATA_GOUV_REFERENCE_ID](#DATA_GOUV_REFERENCE_ID) - [DATA_GOUV_REFERENCE_TYPE](#DATA_GOUV_REFERENCE_TYPE) - Secrets de l'environnement `production` : - [DATA_GOUV_API_URL](#DATA_GOUV_API_URL) - [DATA_GOUV_API_KEY](#DATA_GOUV_API_KEY) - [DATA_GOUV_REFERENCE_ID](#DATA_GOUV_REFERENCE_ID) - [DATA_GOUV_REFERENCE_TYPE](#DATA_GOUV_REFERENCE_TYPE) #### Publication sur le registre npm À chaque fusion sur la branche `main`, l'outil est publié sur [npm](https://www.npmjs.com/) - Organisation: [@gouvfr-anct](https://www.npmjs.com/org/gouvfr-anct) - Package: [@gouvfr-anct/mednum](https://www.npmjs.com/package/@gouvfr-anct/mednum) ##### Transformations et publication automatique Les workflows GitHub [validate.yml](.github%2Fworkflows%2Fvalidate.yml) et [transform-and-publish.yml](.github%2Fworkflows%2Ftransform-and-publish.yml) se chargent de transformer et de publier automatiquement les données : - `validate.yml` est lancé à chaque push sur une branche en cours de développement. Les données sont publiées dans un [environnement de démo de data.gouv](https://demo.data.gouv.fr/fr/organizations/cartographie-nationale-des-lieux-de-mediation-numerique/). Pour qu'une nouvelle source de données soit prise en compte, il faut bien penser à l'ajouter dans le job `publish-to-data-gouv` : une `strategy` de type `matrix` définie chaque `source` à transformer et publier. - `release.yml` est lancé à chaque fusion sur `main`. Les données sont publiées dans [l'organisation Cartographie Nationale des lieux de médiation numérique sur data.gouv](https://data.gouv.fr/fr/organizations/cartographie-nationale-des-lieux-de-mediation-numerique/). Pour qu'une nouvelle source de données soit prise en compte, il faut bien penser à l'ajouter dans le job `publish-to-data-gouv` : une `strategy` de type `matrix` définie chaque `source` à transformer et publier. - `daily` est lancé tous les jours à 04:15 AM. Les données sont publiées dans [l'organisation Cartographie Nationale des lieux de médiation numérique sur data.gouv](https://data.gouv.fr/fr/organizations/cartographie-nationale-des-lieux-de-mediation-numerique/). Pour qu'une nouvelle source de données soit prise en compte, il faut bien penser à l'ajouter dans le job `publish-to-data-gouv` : une `strategy` de type `matrix` définie chaque `source` à transformer et publier.