Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jbuget/todolist
Yet another TodoList API
https://github.com/jbuget/todolist
Last synced: about 2 months ago
JSON representation
Yet another TodoList API
- Host: GitHub
- URL: https://github.com/jbuget/todolist
- Owner: jbuget
- License: agpl-3.0
- Created: 2021-11-01T17:39:45.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-08-26T10:03:38.000Z (over 2 years ago)
- Last Synced: 2023-03-24T06:42:19.438Z (almost 2 years ago)
- Language: TypeScript
- Homepage:
- Size: 589 KB
- Stars: 3
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# 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
- [Démo](https://todolist.osc-fr1.scalingo.io/tasks)
- [Twitch](https://twitch.tv/jeremybuget)
- [YouTube](https://www.youtube.com/channel/UCCA8eDqAjDSsWPUftDzWozA)
- [GitHub](https://github.com/jbuget/todolist)### 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 superiorLes 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](https://fr.wikipedia.org/wiki/GNU_Affero_General_Public_License).
## 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)