/ibeer

Primary LanguageTypeScriptApache License 2.0Apache-2.0

iBeer - Craft Beer E-commerce

iBeer Logo

Overview

iBeer is a craft beer e-commerce developed in Node.js, employing advanced practices of Domain Driven Design (DDD), CQRS, and Clean Architecture. The project features two databases, one for write operations (PostgreSQL) and another for read operations (MongoDB). The coordination between these databases is managed by a custom event bus, promoting consistency and integrity in the data.

Table of Contents

Features

  • Craft beer commerce
  • Implementation of DDD, CQRS, and Clean Architecture
  • PostgreSQL for write operations
  • MongoDB for read operations
  • Data synchronization through a custom event bus
  • Containerized with Docker
  • Container management with Docker Compose

Prerequisites

Before starting, make sure you have Docker and Docker Compose installed on your environment.

Project Structure

iBeer is composed of 4 layers:

  • Application: Responsible for orchestrating business operations.
  • Domain: Responsible for defining business rules.
  • Infrastructure: Responsible for implementing integrations with external services.
  • Presentation: Responsible for implementing user communication interfaces.

Tech Stack:

  • Node.js
  • TypeScript
  • Express
  • Prisma
  • Mongoose
  • PostgreSQL
  • MongoDB
  • Docker
  • Docker Compose

Getting Started

Configuration

Create a .env file at the root of the project with the necessary configurations, such as environment variables for database connections. Refer to the .env.example file for more details.

Start Containers

# Start Docker containers
docker compose --env-file .env up -d --build --force-recreate app_dev

Run Prisma Migrations

# Run Prisma migrations
docker compose --env-file .env exec app_dev yarn prisma migrate reset

License

This project is licensed under the Apache License - see the LICENSE file for details.