Skip to content
This repository has been archived by the owner on Jun 10, 2024. It is now read-only.

Latest commit

 

History

History
28 lines (20 loc) · 2.05 KB

winforms-wcf.md

File metadata and controls

28 lines (20 loc) · 2.05 KB

eShopModernizingWCFWinForms

DISCLAIMER

IMPORTANT: The current state of this sample application is BETA, consider it version a 0.01, therefore, many areas will be improved and changed significantly. This is purely built with the purpose of showing off a concept/demo at this point.

WinForms

Introduction

This sample project shows how to modernize a traditional Line of Business WinForms applications. The WinForms front-end is a fictional inventory app which allows it's users to track inventory for a variety of items being sold through their store. You can look at inventory counts for particular items at different calendar dates.

The project showcases the following features:

  • Containerizing a WCF Service and consuming it from a WinForms App
  • Containerizing a SQL database back-end
  • Publishing the SQL database to Azure
  • Calling a ASP.NET Core Web API from a WinForms App
  • Updating a WinForms App to High DPI compatibility
  • Deploying a WinForms App via Centennial

Repository and Project Structure

Because this repo illustrates the modernization of a legacy app, there are two folders containing separate solutions: a legacy version (eShopWinForms) and a modernized version (eShopWinFormsModernized).

  • Legacy: This solution is the raw WinForms (no High DPI support) interfacing with a local WCF service which talks with a local SQL database.
  • Modernized: This solution contains all of the features called out above. The front-end becomes High DPI-aware, the WCF service and SQL databases are wrapped into containers, and the WCF service is partially broken out into an ASP.NET Core Web API, callable from our front-end.

Each component of the solution is broken into it's own project (frontend, WCF, etc).

Application Walkthrough

We've broken out a full walkthrough of converting from a legacy version to the modernized version in the wiki. Go check out the wiki to get a step-by-step explanation of the features called out in this readme.