OpenDataAPI/README.md

77 lines
3.1 KiB
Markdown
Raw Permalink Normal View History

2024-02-08 12:28:51 +01:00
# Project Open Data
2023-12-11 13:59:00 +01:00
Création d'une API unifié pour accéder à l'ensemble des données dont P4Pillon a besoin.
Le principe du projet est de pouvoir intérroger les données de l'open data depuis un réseau local et ainsi s'affranchir des pannes d'internet ou des APIs. Les données pourront être mise à jour régulièrement pour permettre d'avoir les dernières mise à jour.
2024-01-24 16:29:09 +01:00
## Liens
- [Source du projet](https://forge.p4pillon.org/P4Pillon/data)
2024-02-09 14:49:03 +01:00
- [Gestion des tâches](https://forge.p4pillon.org/P4Pillon/OpenDataAPI/projects/3)
- [API de P4Pillon](https://data.p4pillon.org)
- [Interface Swagger pour l'API](https://ui.data.p4pillon.org)
- [Support et questionnement](https://matrix.to/#/!UXjiUOiWQMEsMgMNMN:converser.eu)
2024-01-24 16:29:09 +01:00
## Données
### ✅ FINESS
2024-01-24 16:29:09 +01:00
2024-02-06 11:49:02 +01:00
Informations sur les établissements sanitaires, sociaux, médico-sociaux, et de formation aux professions de ces secteurs.
2024-01-24 16:29:09 +01:00
2024-02-06 11:49:02 +01:00
Liens :
- [Site web](https://finess.esante.gouv.fr/)
- [Page web sur l'Open Data du gouvernement](https://www.data.gouv.fr/fr/datasets/finess-extraction-du-fichier-des-etablissements/)
2024-01-24 16:29:09 +01:00
### ✅ INPI
2024-01-24 16:29:09 +01:00
2024-02-06 11:49:02 +01:00
L'Institut national de la propriété industrielle, abrégé par le sigle INPI, est un établissement public à caractère administratif, placé sous la tutelle du ministère français de l'Économie, de l'Industrie et du Numérique.
Il y a 2 posibilités pour récupérer les données de l'ensemble des entreprises française :
2024-01-24 16:29:09 +01:00
- depuis l'API
- depuis [des fichiers](https://www.data.gouv.fr/fr/datasets/base-sirene-des-entreprises-et-de-leurs-etablissements-siren-siret/)
2024-02-06 11:49:02 +01:00
## Composants logiciels du projet
- Base de données : [PostgreSQL](https://www.postgresql.org/)
- API : [PostgREST](https://postgrest.org/) ([Documentation](https://postgrest.org/en/stable/explanations/install.html#docker))
- UI : [Swagger UI](https://swagger.io/tools/swagger-ui/)
2024-02-08 12:28:51 +01:00
- Virtualisation : [Docker](https://docs.docker.com/)
2024-02-06 11:49:02 +01:00
- Orchestrateur : [Docker Compose](https://docs.docker.com/compose/)
2024-02-08 12:28:51 +01:00
## Script
2024-02-08 12:28:51 +01:00
Un script permet d'initialiser le projet en téléchargeant les dépendences, les données de l'Open Data ainsi que de transformer ses données en fichiers CSV.
Il faut avoir Docker d'installé et executer cette commande :
```bash
bash build.sh
```
2024-02-06 11:49:02 +01:00
### Docker Compose
Nous utilisons Docker Compose pour la mise en place des différents services.
Le projet propose 3 fichiers permettant une execution local ou sur un serveur ayant un serveur Traefik de configuré.
La configuration se fait à l'aide d'un fichier `.env`, vous devez modifier les valeurs du fichier `.env.template`.
Voici quelques commandes possibles :
2024-02-08 12:28:51 +01:00
```bash
docker compose --env-file .env up -d # Création des conteneurs
docker compose --env-file .env down -v # Suppresion des conteneurs ainsi que des données
2024-02-06 11:49:02 +01:00
```
### PostgreSQL
2024-02-08 12:28:51 +01:00
La fonction `COPY` est utilisé dans les fichiers SQL du dossier `./initdb` permettant d'importer les données d'un fichier CSV dans une base de données.
2024-02-06 11:49:02 +01:00
### PostgREST
2024-02-08 16:10:14 +01:00
- [Pour la configuration](https://postgrest.org/en/latest/configuration.html#environment-variables)
- [Pour requêter des données](https://postgrest.org/en/stable/references/api/tables_views.html#horizontal-filtering-rows)