Coder Social home page Coder Social logo

alexandermikuta / clean-architecture-boilerplate Goto Github PK

View Code? Open in Web Editor NEW

This project forked from ccocoual/clean-architecture-boilerplate

0.0 0.0 0.0 937 KB

Clean architecture project in monorepository using Nest.js and Nuxt.js

Shell 3.23% JavaScript 7.76% TypeScript 83.00% Vue 6.01%

clean-architecture-boilerplate's Introduction

README

Directory structure

front

The frontend application built with Nuxt.js. The application uses a component-based architecture pattern.

Components architecture

The front application follows a component based architecture with:

  • front/components/base-components: base components that the only point is to display data and emit events
  • front/components/[dummy]: functional components that implements business logic and use base components
  • front/pages: pages that fetch the data and emit request to backend

API service

Methods to interact with REST Api are defined in front/services/api.service.ts. This service is inject in Nuxt Context to be able to access it from components in front/plugins/api-service.plugin.ts.

VueX store

We use a VueX store to have a frontend cache to store data from forms or fetched from backend. The store is organize by modules to simplify its evolution.

back

The backend application built with NestJS. The application uses a Clean Architecture pattern (see below).

Clean Architecture

The back application is designed using a Clean Architecture pattern (also known as Hexagonal Architecture). Therefore SOLID principles are used in code, especially the Dependency Inversion Principle (do not mix up with the classic dependency injection in NestJS for example).

Concretely, there are 3 main packages: domain, use_cases and infrastructure. These packages have to respect these rules:

  • domain contains the business code and its logic, and has no outward dependency: nor on frameworks (NestJS for example), nor on use_cases or infrastructure packages.
  • use_cases is like a conductor. It will depend only on domain package to execute business logic. use_cases should not have any dependencies on infrastructure.
  • infrastructure contains all the technical details, configuration, implementations (database, web services, etc.), and must not contain any business logic. infrastructure has dependencies on domain, use_cases and frameworks.

Swagger documentation

To have an executable documentation of back APIs, Swagger documentation is available on the /api/doc endpoint.

doc

Contains the technical documentation, such as Architecture Decision Records (ADR) (see below).

ADR

An Architecture Decision Record (ADR) is a document that captures an important architectural decision made along with its context and consequences. For more details, see description by Michael Nygard.

We use Nat Pryce's adr-tools to keep the same pattern when adding a new ADR.

Git strategy

We use Feature Branch pattern and Gitmoji to easily categorize commits using emojis.

Continuous Deployment

Every time a commit is pushed on master branch, it will be automatically deployed to DEV environment. Deployment to DEMO environment is on demand with a manual trigger.

How-to

The npm commands are the same, whether you are on back or front application.

Requirements

  • Node LTS 12.x

Install

npm install

Test

npm test

Run

npm run start:dev

Database migrations

When running back for the first time, or after database deletion, you have to run migrations to create a local database, and another migration to populate it.

# Create database schema
npm run typeorm:migration:run

# Populate database
npm run typeorm:seed:run

REST API

  • Swagger documentation: /api/doc/

Environment variables

See INSTALL.md.

clean-architecture-boilerplate's People

Contributors

ccocoual avatar renovate-bot avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.