Giter Site home page Giter Site logo

clean-architecture-solution-template-oidc's Introduction

Clean Architecture Solution Template using Oidc (OpenId Connect)

Technologies

Others

  • Swagger
  • KeyCloak Oidc
  • PostgreSQL
  • DbUp

Getting Started

  1. Install the latest .NET 5 SDK
  2. Clone the project
  3. Run Infrastructure.DbUp console project
  4. Run WebAPI project

Database Configuration

The API uses PostgreSQL database.
DbUp is used for database schema change management.

Prerequisites:

  1. Install PostreSQL database locally
  2. Install pgAdmin4 to manage PostreSQL databases

Update Infrastructure.DbUp/appsettings.json as follows:

  • Verify that the DefaultConnection connection string within appsettings.json points to a valid PostgreSQL Server instance.
  • When you run the application the database will be automatically created (if necessary) and the latest migrations will be applied.

Update WebAPI/appsettings.json as follows:

  • Verify that the DefaultConnection connection string within appsettings.json points to the same PostgreSQL Server instance as in Infrastructure.DbUp/appsettings.json.

Overview

Domain

This will contain all entities, enums, exceptions, interfaces, types and logic specific to the domain layer.

Application

This layer contains all application logic. It is dependent on the domain layer, but has no dependencies on any other layer or project. This layer defines interfaces that are implemented by outside layers. For example, if the application need to access a notification service, a new interface would be added to application and an implementation would be created within infrastructure.

Infrastructure

This layer contains classes for accessing external resources such as file systems, web services, smtp, and so on. These classes should be based on interfaces defined within the application layer.

WebAPI

This layer depends on both the Application and Infrastructure layers, however, the dependency on Infrastructure is only to support dependency injection. Therefore only Startup.cs should reference Infrastructure. When run, it opens a Swagger API documentation page.

Others

  • CORS support: In WebAPI/appsettings.json, property CorsOrigins contains allowed origins separated by comma.
  • Security Headers middleware that adds some security headers.
  • Health endpoint that can be found at {app_url}/health -> It tests if the application and the database are alive.

Testing (TBD)

  • Unit tests: TBD
  • Integration tests: TBD

License

This project is licensed with the MIT license.

clean-architecture-solution-template-oidc's People

Contributors

gheorghevolosenco avatar

Watchers

 avatar

Forkers

bartvda7

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.