Fully Documented and Authenticated REST API

Fully Documented and Authenticated REST API

Ecommerce API

A secure eCommerce REST API featuring JWT authentication and role-based access control (RBAC), with comprehensive OpenAPI (Swagger) documentation, API request validation using class-validator for type safety, and a custom logging filter for comprehensive API monitoring.

What tools it uses

NestJS
VueJS
MySQL
Stripe
TypeScript
NodeJS
Express
OpenAPI Swagger
Combodocs
Hetzner
Docker
Coolify
GitHub Actions
Cloudflare
Traefik
PassportJS

Links

Github Demo OpenAPI Swagger Combodocs 

How I built it

This eCommerce API was developed using NestJS, TypeScript, and Express, with a focus on providing a secure and scalable backend for web applications. Key features and deployment details include:
  • Backend Framework: Built with NestJS, leveraging TypeScript and Express for robust and scalable API development.
  • Security: Includes both authorized routes for privileged users and unauthenticated routes accessible to all users. Implemented class-validator for request validation, ensuring type safety and informative error responses.
  • Logging: Features a custom logging filter to record all API requests and capture exceptions. Logs are available with pagination on admin routes for detailed monitoring and analysis.
  • Documentation: Each API route is documented using the OpenAPI (Swagger) standard, and the entire application is further detailed with Compodoc, providing comprehensive inline comments and structure explanations.
  • Deployment:
    • Deployed on Hetzner servers using Docker Compose and managed through Coolify for automated deployments.
    • Utilizes Cloudflare for CDN, SSL, DNS, and DDoS protection, with the frontend also hosted on Cloudflare Pages.
    • CI/CD: Integrated with GitHub Actions for automated build, containerization, and deployment. The CI/CD pipeline builds the application, creates a Docker container, and pushes it to GitHub Container Registry. Coolify then deploys the latest image from the registry using a webhook.
    • Load Balancing: Employs Traefik for load balancing between Docker containers, with configuration files stored on the server and mounted as Docker volumes to manage container ephemerality.
    • Health Checks: Docker Compose files include scheduled health checks to ensure container reliability.
This setup enhances deployment efficiency, improves application reliability, and supports scalable growth, making it a comprehensive solution for modern eCommerce needs.

Architecture Diagram

  1. Coolify: Manages the deployment of Docker containers on the Hetzner server, ensuring that the latest versions of the applications are running.
  2. Hetzner Server: Hosts the entire infrastructure, including Docker Compose, Traefik load balancer, and MySQL database.
  3. Traefik Proxy Load Balancer: Distributes incoming traffic across multiple instances of the eCommerce API containers, ensuring high availability and reliability.
  4. Docker Compose: Orchestrates the deployment of multiple containers, including the eCommerce API and MySQL database. Utilizes Docker volumes for persistent storage and performs regular health checks to ensure container stability.
  5. GitHub Actions CICD Pipeline: Automates the build and deployment process. Upon pushing code to the repository, the pipeline builds the Docker images, pushes them to the GitHub Container Registry, and triggers Coolify to redeploy the updated containers.
  6. GitHub Container Registry: Stores the Docker images of the application, allowing for version control and easy deployment of the latest builds.
  7. Cloudflare: Provides a Content Delivery Network (CDN) for faster content delivery, DDoS protection, DNS resolution, and SSL certificates for secure communication.
  8. Cloudflare Pages: Hosts the frontend of the eCommerce application, ensuring that users can access the web pages quickly and securely.

Dockerfile

Docker Compose

Github Actions Yaml

Traefik Config