Skip to content

Latest commit

 

History

History
79 lines (56 loc) · 2.59 KB

README.md

File metadata and controls

79 lines (56 loc) · 2.59 KB

TaskList

TaskList est l'application Node/TypeScript développée en live coding au cours de l'émission "L'Atelier du Code".

D'un point de vue fonctionnel, il s'agit d'un projet basique de gestion de choses à faire (a.k.a. des Todos).

L'application, son architecture et son infrastructure sont considérées sous un angle transactionnel/CRUD (vs. évènementiel ou temps réel).

L'objectif du projet est de montrer la mise en place, le développement, le déploiement, l'industrialisation et la gestion d'une application Web dans les conditions proches d'un cadre professionnel.

Liens

Technologies

  • Node/npm
  • TypeScript/ts-node
  • ESLint
  • Jest/ts-jest
  • Fastify
  • Dotenv
  • PostgreSQL
  • Prisma
  • Docker/Compose
  • Scalingo

Méthodologies et philosophies

  • Extreme Programming
  • TDD
  • Software Craftsmanship
  • CI/CD
  • Clean Code
  • MD10

Installation

Prérequis

Le projet nécessite les outils / programmes suivants :

  • Git v2.33.0
  • Node (npm) v14.18.1 (v6.14.15) or superior ; v16.13.0 (v8.1.0) recommandée
  • Docker v20.10.8 or superior

Les versions indiquées sont celles utilisées dans le cadre du développement de l'application. Il est possible qu'elle fonctionne avec des versions différentes, mais ce n'est pas garantit.

Étapes

git clone [email protected]:jbuget/todolist.git
cd todolist
npm run configure

⚠️ Si la commande docker compose up -d ne fonctionne pas (car ancienne version de Docker ou version pour Linux), essayer la commande docker-compose up -d

Configuration

Il est possible de paramétrer certains aspects de l'application (logger, base de données) via des variables d'environnement.

Le moyen le plus simple est de renseigner/modifier celles-ci depuis le fichier .env propre à votre environnement.

Licence

Ce logiciel est développé et distribué sous licence AGPL v3.

Roadmap

  • Mettre en place un Swagger / OpenAPI
  • Rédiger un guide de design de l'API
  • Ajouter des métriques système (pour Prometheus)
  • Voir ce qu'on peut faire avec pm2 (monitoring)
  • Ajouter un Aggregate Root User, intéressant pour voir comment gérer des relations, niveau HTTP/REST ou ORM/DB
  • Ajouter des tests de charge avec Artillery
  • Mettre en place une gestion des erreurs
  • Faire en sorte que les tâches soient chiffrées (par compte utilisateur)