Skip to content

Latest commit

 

History

History
87 lines (59 loc) · 4.25 KB

README.md

File metadata and controls

87 lines (59 loc) · 4.25 KB

TODO : Generate Opening template paragraph

Technologies

Getting Started

Software Prerequisites

In order to run this solution, you will need the following software prerequisites installed on your development machine.

Clone Solution

Clone the following solution to your development machine.

Secrets Configuration

For development, the 'Secrets Manager' is utilized for managing sensitive data.
More information about Secrets Manager

To create and access your individual development secrets file, right click on the 'Api' project and select 'Manage User Secrets' from the context menu.
Paste the following code into your secrets file and update your connection string.\

{
  "ConnectionStrings": {
    //This will be your localhost database connection string. If applicable, modify.
    "NorthwindContext": "Server=localhost;Database=Northwind;Trusted_Connection=True;MultipleActiveResultSets=true"
  }
}

Database Migrations

In order to prepopulate your configured localhost database, you must execute Database Migrations against it.
Open up your 'Package Manager' (In VS, go to 'View' --> 'Other Windows' --> 'Package Manager')
and execute the following snippet.

update-database -Context NorthwindContext

After you successfully run the above snippet, your configured localhost database should be seeded with a subset of the 'Northwind' database.

Solution Architecture Overview

Domain

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

Application

This layer contains all application business 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' layer.

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.

Api

This layer is an API based on Restful Principals. 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 by way of the services.AddMyInfrastructure(Configuration); method.
If you need to add more services, you can add the service to the Infrastructure.DependencyInjection.cs file.

Templator

This layer is an html creator using standard MVC (Model/View/Controller) conventions. It uses domain objects as the 'Model' and .cshtml files as the 'View' to create html templates for emails or other html needed services.

Support

If you are having problems, please let us know by [To Do : Add contact email or link].

License

This project is licensed with the MIT license.