Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jamesbrel/node_mdc_and_modular_arch

MDC, modular architecture is a particularly interesting concept... for a project that is structured, maintainable and scalable without a hitch...
https://github.com/jamesbrel/node_mdc_and_modular_arch

express inversify inversify-express javascript modularization mvc-architecture node typescript

Last synced: about 2 months ago
JSON representation

MDC, modular architecture is a particularly interesting concept... for a project that is structured, maintainable and scalable without a hitch...

Awesome Lists containing this project

README

        

# Node Server : MDC and Modular Architecture

### Author : James Brel

### Contact : [email protected]
---

logo

---

## Architecture
the architecture of each feature is based on the MDC which is constituted mainly of 3 layers :
- Data
- Models
- Controllers
```
πŸ“¦features
β”— πŸ“‚say_hello_to_world
┃ ┣ πŸ“‚controllers
┃ ┣ πŸ“‚data
┃ β”— πŸ“‚models
```

## General Folder Structure Tree
```
πŸ“¦project
┣ πŸ“‚.vscode
┃ β”— πŸ“œsettings.json
┣ πŸ“‚envs
┃ ┣ πŸ“œdev.env
┃ ┣ πŸ“œprod.env
┃ β”— πŸ“œstaging.env
┣ πŸ“‚lib
┃ ┣ πŸ“‚src
┃ ┃ ┣ πŸ“‚core
┃ ┃ ┃ ┣ πŸ“‚configs
┃ ┃ ┃ ┃ ┣ πŸ“œinversify_config.ts
┃ ┃ ┃ ┃ ┣ πŸ“œmiddle_config.ts
┃ ┃ ┃ ┃ β”— πŸ“œserver_config.ts
┃ ┃ ┃ β”— πŸ“œinit.ts
┃ ┃ ┣ πŸ“‚features
┃ ┃ ┃ ┣ πŸ“‚app_feats
┃ ┃ ┃ ┃ β”— πŸ“‚say_hello_to_world
┃ ┃ ┃ ┃ ┃ ┣ πŸ“‚controllers
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œsay_hello_to_world_controller.ts
┃ ┃ ┃ ┃ ┃ ┣ πŸ“‚data
┃ ┃ ┃ ┃ ┃ ┃ ┣ πŸ“‚impls
┃ ┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œhello_to_world_impl.ts
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“‚interfaces
┃ ┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œhello_to_world_inter.ts
┃ ┃ ┃ ┃ ┃ β”— πŸ“‚models
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œ.gitkeep
┃ ┃ ┃ β”— πŸ“‚users_feats
┃ ┃ ┃ ┃ β”— πŸ“‚feature_name
┃ ┃ ┃ ┃ ┃ ┣ πŸ“‚controllers
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œ.gitkeep
┃ ┃ ┃ ┃ ┃ ┣ πŸ“‚data
┃ ┃ ┃ ┃ ┃ ┃ ┣ πŸ“‚impls
┃ ┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œ.gitkeep
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“‚interfaces
┃ ┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œ.gitkeep
┃ ┃ ┃ ┃ ┃ β”— πŸ“‚models
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œ.gitkeep
┃ ┃ β”— πŸ“‚shared
┃ ┃ ┃ ┣ πŸ“‚constants
┃ ┃ ┃ ┃ ┣ πŸ“œapi_const.ts
┃ ┃ ┃ ┃ ┣ πŸ“œnumber_const.ts
┃ ┃ ┃ ┃ β”— πŸ“œstring_const.ts
┃ ┃ ┃ ┣ πŸ“‚extensions
┃ ┃ ┃ ┃ β”— πŸ“œexpress.d.ts
┃ ┃ ┃ ┣ πŸ“‚global
┃ ┃ ┃ ┃ β”— πŸ“œstring_variable.ts
┃ ┃ ┃ ┣ πŸ“‚helpers
┃ ┃ ┃ ┃ β”— πŸ“œ.gitkeep
┃ ┃ ┃ ┣ πŸ“‚logs
┃ ┃ ┃ ┃ β”— πŸ“œlogger.ts
┃ ┃ ┃ ┣ πŸ“‚middlewares
┃ ┃ ┃ ┃ ┣ πŸ“œtoken_middle.ts
┃ ┃ ┃ ┃ β”— πŸ“œuploder_middle.ts
┃ ┃ ┃ ┣ πŸ“‚results
┃ ┃ ┃ ┃ ┣ πŸ“œresult_failure.ts
┃ ┃ ┃ ┃ ┣ πŸ“œresult_success.ts
┃ ┃ ┃ ┃ β”— πŸ“œtype.ts
┃ ┃ ┃ β”— πŸ“‚services
┃ ┃ ┃ ┃ ┣ πŸ“‚jwt
┃ ┃ ┃ ┃ ┃ β”— πŸ“‚requests
┃ ┃ ┃ ┃ ┃ ┃ ┣ πŸ“œcreate_token_request.ts
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œverify_token_request.ts
┃ ┃ ┃ ┃ ┣ πŸ“‚mongoose
┃ ┃ ┃ ┃ ┃ ┣ πŸ“‚configs
┃ ┃ ┃ ┃ ┃ ┃ ┣ πŸ“œindex_config.ts
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œmongoose_config.ts
┃ ┃ ┃ ┃ ┃ ┣ πŸ“‚requests
┃ ┃ ┃ ┃ ┃ ┃ ┣ πŸ“œmongoose_delete_request.ts
┃ ┃ ┃ ┃ ┃ ┃ ┣ πŸ“œmongoose_get_request.ts
┃ ┃ ┃ ┃ ┃ ┃ ┣ πŸ“œmongoose_insert_request.ts
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œmongoose_update_request.ts
┃ ┃ ┃ ┃ ┃ ┣ πŸ“‚schemas
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œuser_schema.ts
┃ ┃ ┃ ┃ ┃ β”— πŸ“‚utils
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œroot_util.ts
┃ ┃ ┃ ┃ ┣ πŸ“‚security
┃ ┃ ┃ ┃ ┃ β”— πŸ“‚requests
┃ ┃ ┃ ┃ ┃ ┃ ┣ πŸ“œcrypt_request.ts
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œverify_request.ts
┃ ┃ ┃ ┃ β”— πŸ“‚sequelize
┃ ┃ ┃ ┃ ┃ ┣ πŸ“‚configs
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œ.gitkeep
┃ ┃ ┃ ┃ ┃ ┣ πŸ“‚schemas
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œ.gitkeep
┃ ┃ ┃ ┃ ┃ β”— πŸ“‚utils
┃ ┃ ┃ ┃ ┃ ┃ β”— πŸ“œ.gitkeep
┃ β”— πŸ“œindex.ts
┣ πŸ“‚test
┃ β”— πŸ“œ.gitkeep
┣ πŸ“œ.eslintignore
┣ πŸ“œ.eslintrc
┣ πŸ“œ.gitignore
┣ πŸ“œ.prettierignore
┣ πŸ“œ.prettierrc
┣ πŸ“œbabel.config.json
┣ πŸ“œecosystem.config.cjs
┣ πŸ“œjest.config.json
┣ πŸ“œnodemon.json
┣ πŸ“œpackage.json
┣ πŸ“œreadme.md
┣ πŸ“œtsconfig.json
β”— πŸ“œtypedoc.json
```

## Usage and Configuration

After downloading or cloning the Git Repository

1. go to the **project** folder and copy all the content in your server's project

2. go into your **package.json file**, fill the following points:

- "name" : Specify the Project Name
- "description" : Specify the Project Description
- "url" : "git+url" (complete the url line with the git url of your repository)
- "author" : Specify the Project Author (Organisation name)

3. and type ***npm install*** to install all packages of Dependencies and Dev_Dependencies

---

Copyright Β© 2024 James Brel All Rights Reserved