🌀 Clean Architecture with .NET6, C#10 and React+Redux. Use cases as central organizing structure, completely testable, decoupled from frameworks
Go to file
Ivan Paulovich 5f85f87f6b
Fix docker compose on max (#229)
Startup the whole solution:

```sh
cd .docker
chmod 777 startup.sh
./startup.sh
```
2020-09-05 14:56:25 +02:00
.docker Fix docker compose on max (#229) 2020-09-05 14:56:25 +02:00
.github/workflows Adds identity server 4 2020-09-01 23:12:40 +02:00
.vscode Fix docker compose on max (#229) 2020-09-05 14:56:25 +02:00
accounts-api Adds identity server 4 2020-09-01 23:12:40 +02:00
identity-server Adds identity server 4 2020-09-01 23:12:40 +02:00
wallet-spa Adds identity server 4 2020-09-01 23:12:40 +02:00
.all-contributorsrc docs: update .all-contributorsrc [skip ci] 2020-08-05 09:25:14 +02:00
.gitignore Docker Fix (#111) 2019-11-21 10:56:46 +01:00
CHANGELOG.md Updating build version and changelog for Health Check feature implementation. 2020-08-05 09:14:11 +02:00
Clean-Architecture-Manga.sln Adds identity server 4 2020-09-01 23:12:40 +02:00
Clean-Architecture-Manga.sln.DotSettings Huge Refactoring (#220) 2020-07-27 11:02:25 +02:00
FUNDING.yml Funding settings added 2020-07-08 10:26:30 +02:00
LICENSE Initial commit 2017-12-27 09:58:03 -02:00
README.md Fix docker compose on max (#229) 2020-09-05 14:56:25 +02:00

Clean Architecture with .NET Core & React+Redux 🌀

All Contributors Build Status

Sample implementation of the Clean Architecture Principles with .NET Core. Use cases as central organizing structure, decoupled from frameworks and technology details. Built by small components that are developed and tested in isolation.

We maintain two versions:

Hit the WATCH button to get the latest Clean Architecture updates.

Manga is a Virtual Wallet software in which the customer register an account then manage the balance by Deposits, Withdraws and Transfers.

The Web API's demo is hosted on Azure servers and there's a beautiful Swagger Client available. Swagger Demo

We also support the React client:

React+Redux Demo

Run the Docker container in less than 2 minutes using Play With Docker:

Try in PWD

Build & Run

Run the following commands:

Startup the whole solution:

cd .docker
chmod 777 startup.sh
./startup.sh

Then the following containers should be running docker ps:

Application Port Protocol
Wallet SPA 5010 HTTPS
Accounts API 5005 HTTPS
Identity Server 5000 HTTPS
SQL Server 1433 TCP

Browse to https://localhost:5010 then click on Log In. Trust the self-signed certificate.

If you are prefer dotnet commands then start each service individually:

Expand to get the dotnet run steps.

Generate Self Signed Certificate

dotnet dev-certs https --clean
dotnet dev-certs https -ep $env:USERPROFILE\.aspnet\https\aspnetapp.pfx -p MyCertificatePassword

Spin up SQL Server in a Docker container

docker pull mcr.microsoft.com/mssql/server:2019-latest
docker run -e 'ACCEPT_EULA=Y' -e 'SA_PASSWORD=<YourStrong!Passw0rd>' -p 1433:1433 --name sql1 -d mcr.microsoft.com/mssql/server:2019-latest

Create and Seed Accounts Database

dotnet tool update --global dotnet-ef --version 3.1.6
dotnet ef database update --project accounts-api/src/Infrastructure --startup-project accounts-api/src/WebApi

Running Services

Identity Server

dotnet run --project identity-server/src/IdentityServer.csproj

Account API

dotnet run --project accounts-api/src/WebApi/WebApi.csproj

Wallett SPA

pushd wallet-spa/src/ClientApp
npm install
popd
dotnet run --project wallet-spa/src/WalletSPA.csproj --launch-profile WalletSPA

Motivation

Learn how to design modular applications.

Explore the .NET Core features.

Learn how to design modular applications

Learning how to design modular applications will help you become a better engineer. Designing modular applications is the holy grail of software architecture, it is hard to find engineers experienced on designing applications which allows adding new features in a steady speed.

Explore the .NET Core features

.NET Core brings a sweet development environment, an extensible and cross-platform framework. We will explore the benefits of it in the infrastructure layer and we will reduce its importance in the application and domain layers. The same rule is applied for modern C# language syntax.

Learn from the open source community

This is continually updated, open source project.

Contributions are welcome!

Contributing

Learn from the community.

Feel free to submit pull requests to help:

  • Fix errors.
  • Refactoring.
  • Build the Front End.
  • Submit issues and bugs.

The Discussão em Português is pinned for the large community of brazillian developers.

Index of Clean Architecture Manga

Home

Use Cases

Flow of Control

Architecture Styles

Design Patterns

Domain-Driven Design Patterns

Separation of Concerns

Encapsulation

Test-Driven Development TDD

Fakes

SOLID

.NET Core Web API

Entity Framework Core

Environment Configurations

DevOps

Docker

Contributors

Thanks goes to these wonderful people (emoji key):


Ivan Paulovich

🎨 ⚠️ 💻

Petr Sedláček

⚠️ 💻

Gus

🎨 ⚠️

arulconsultant

⚠️

Guilherme Silva

🎨 ⚠️ 💻

Ondřej Štorc

🎨 ⚠️

Marlon Miranda da Silva

🎨 ⚠️

NicoCG

⚠️

Filipe Augusto Lima de Souza

🎨 ⚠️ 💻

sshaw-sml

⚠️ 💻

Matheus Neder

⚠️

димитрий матиенко

🎨 ⚠️

morphlogic

⚠️ 💻

Felipe Lambert

⚠️ 💻

Philippe Matray

🎨 💻

Leandro Fagundes

💬

Bart van Ommen

🤔 💻

qpippop

🤔

Cesar Pereira

💻

Edvaldo Farias

💻

Sergio Broccardi

💻

cuno92

💻

Vinícius Mamoré

💻

dyavolick

💻

felipetofoli

🎨 💻

This project follows the all-contributors specification. Contributions of any kind welcome!

Hit the FORK button and show Clean Architecture on your profile.