This project demonstrates one possible way to setup and organize your Visual Studio project. As this project progresses it will be broken apart into various layers that can be consumed by one of the example project applications provided. You can find my ePortfolio here.
Note: Lead developer should maintain this and all files in the repository.
Authors 
ChangeLog 
Contributing
- .NET
- Visual Studio
- SQL Server Express
- Docker Desktop
- Visual Studio Code
- SQL Server Management Studio
- Clone the repository to your local machine.
- Locate the file docker_setup.ps1 in the root of the project and run this in PowerShell which will setup the Docker Containers and Dependencies.
- To get started with this project, you will need to clone the repository and then open the solution in Visual Studio.
- Once the solution is open, you will want to build the solution. This will download all of the NuGet packages that are required or the project.
- Open the Database.Example project and build the project then publish using the "StartupExample.publish.xml" profile.
- There should be no need to update the secrets.json file with the connection string as it should be configured in the appsettings.json file for SQL Express.
- Start Visual Studio and open the solution.
- Open the Database.Example project and build the project then publish using the "StartupExample.Docker.publish.xml" profile. Using the default password of "P@ssword123!".
- MailHog was added as an email trap.
- Open Telemetry was added to the project to help with debugging and development and can be found here after starting the docker containers.
- Watch the following video for why and how its used: The Logging Everyone Should Be Using in .NET
 
- Once the project has been built and the database has been created, you can run any of the applications.
If you are using CodeSpaces you'll want to update your container git configuration profile. Be sure to update with your appropriate name and email details.
git config --global user.name "Your Name"
git config --global user.email "[email protected]"
This document outlines the resources generally needed to do development on this project. Some resources are not critical but recommended.
β Required Resource β
This includes .NET 8 and .NET 9.
winget install Microsoft.DotNet.SDK.8
winget install Microsoft.DotNet.SDK.9
π Recommended π
This utility provides windows a Unix like tabbed console window manager.
winget install Microsoft.WindowsTerminal
β Required Resource β
DevOps customized commands are written using the latest version of PowerShell.
winget install Microsoft.PowerShell
π Recommended π
These tools provide CLI support for interacting with and managing Azure resources from your console. Some of these tools may be required depending on some of the development work required such as FunctionsCoreTools if doing function app development.
winget install Microsoft.AzureCLI
winget install Microsoft.Azd
winget install Microsoft.Azure.FunctionsCoreTools
β Required Resource β
This adds the windows GIT client to interact with git based repositories.
winget install Git.Git
π Recommended π
These are two recommended GUI wrapper clients for the git Cli. These are not required but maybe helpful in managing repository changes and visualizing history and branching better. Atlassian's tool works very well at providing a history tree view for tracking changes. Both Visual Studio and VS Code have git support making these tools optional.
winget install Atlassian.Sourcetree
winget install GitHub.GitHubDesktop
π Recommended π 
β License Required β
When performing merging of branches, the BeyondCompare tool has been fantastic. This tool also supports comparisons between folders making it easier to perform diffs between two large directory structures. This tool also integrates well with Atlassian Source Tree.
winget install ScooterSoftware.BeyondCompare.5
If you need to work with Azure Blob Storage this Visual GUI tool provides easy access and management of content stored in an Storage resource in Azure.
winget install Microsoft.Azure.StorageEmulator
winget install Microsoft.Azure.StorageExplorer
π Recommended π
You can install either Postman or Bruno
winget install Postman.Postman
winget install Bruno.Bruno
π Recommended π
Having a local instance of SQL Server can be helpful for development purposes.
winget install Microsoft.SQLServer.2022.Express
β Required Resource β
Our primary development must use Visual Studio and / or Visual Studio Code
winget install Microsoft.VisualStudio.2022.Enterprise
winget install Microsoft.VisualStudioCode
π Recommended π
Having the ability to query the database is required, however, SQL Server Management Studio is recommended as the primary tool for doing so. Notepad++ is a lightweight text editor that is very handy.
winget install Microsoft.SQLServerManagementStudio
winget install Notepad++.Notepad++
β License Required β
Only request this tool if there is a use case that is needed. This tool makes querying databases very nice. It provides support for LINQ or direct queries. You can also validate / verify queries using LINQ within this editor making testing easier when developing Entity Framework calls to the database.
winget install LINQPad.LINQPad.7
π Recommended π 
β License Required β
Highly recommended. This tool should be used periodically for its refactor and C# linting fix up capabilities for C# code.
JetBrains.Toolbox is a centralized application manager that simplifies the installation and management of JetBrains IDEs and tools. JetBrains.ReSharper is a Visual Studio extension that enhances code quality and productivity with advanced refactoring, navigation, and code analysis features.
winget install JetBrains.Toolbox
winget install JetBrains.ReSharper
π Recommended π 
β License Required β
This resource provides local development tools and resources will speed up developer setup and configuration and provide diagnostic and debugging resources not previously available. The number of options and tools is near limitless.
winget install Docker.DockerDesktop
π Recommended π
It is recommended to periodically run the dotnet workload update command, as this will help keep your local development tools and resources up to date. Running Visual Studio updates do not always update all of the dotnet resources. If you desire experimenting with Aspire resources it is recommended to install the wasm-tools and aspire workloads. Lastly, the LibraryManager provides resources for using libman.json configuration files to automatically download web resources such as jQuery, Bootstrap, and other libraries for web development.
dotnet workload update
dotnet workload install wasm-tools
dotnet workload install aspire
dotnet tool install -g Microsoft.Web.LibraryManager.Cli
This will update PowerShell permissions settings to grant unsigned scripts access to run locally.
Run as local machine administrator
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope LocalMachine
Set-ExecutionPolicy -ExecutionPolicy Unrestricted -Scope CurrentUser
π Recommended π 
A DevContainer is a development environment defined by a Docker container, which includes all necessary tools, libraries, and dependencies for a project. It ensures a consistent development setup across different machines, simplifies onboarding, and enhances productivity by providing a pre-configured environment that mirrors production settings. DevContainers are commonly used with Visual Studio Code to streamline development workflows and improve collaboration.
The following Docker Images and Container resources are provisionally approved for local development environment use ONLY. These images and resources may not at any time be deployed outside of your local development environment. They are to be used as tools, utilities, and resources at the local development level only.
Container Images
- datalust/seq
- docker.io/library/redis
- ghcr.io/azure/azure-dev/azd
- ghcr.io/devcontainers/features/common-utils
- ghcr.io/devcontainers/features/docker-in-docker
- ghcr.io/devcontainers/features/dotnet
- aspire
- wasm-tools
 
- ghcr.io/devcontainers/features/github-cli
- ghcr.io/devcontainers/features/powershell
- ghcr.io/devcontainers/features/node
- mailhog/mailhog
- mcr.microsoft.com/azure-storage/azurite
- mcr.microsoft.com/azure-messaging/servicebus-emulator
- mcr.microsoft.com/azure-messaging/eventhubs-emulator
- mcr.microsoft.com/devcontainers/dotnet:1-9.0
- mcr.microsoft.com/dotnet/sdk
- mcr.microsoft.com/dotnet/aspnet
- mcr.microsoft.com/mssql/server
- wiremock/wiremock