School Project from Multi-tier applications development class in Faculty of Technical Sciences - University of Novi Sad 🏫
Use these instructions to get the project up and running.
You will need the following tools:
Follow these steps to get your development environment set up:
- Restore NuGet Packages & Build solution
- (Optional) Set solution to multiple startup projects ( Right Click Solution > Properties > Multiple Startup Perojects) where
Server.WCF
project will be loaded first and thenClient.DesktopUI
- Run solution
Note: For best user experience (without interruptions from debugger) it is advised to run project without debugging (either with
CTRL+F5
or by running it inRelease
Mode).
This section will focus on how to use this application, as well as give brief explanation on what each display does.
Console Application which hosts WCF
services. It displays log information which can be configured in App.config by setting level
value to one of the following: (ALL, DEBUG, INFO, WARN, ERROR, FATAL, OFF)
<log4net>
<root>
<level value="INFO"/>
</root>
</log4net>
User can close Server by pressing ENTER
on keyboard.
WPF Desktop Application through which User can interract with Server.
Once the application has been run, user will be greeted with Login screen after which he will have different view options based on his role (Administrator or Regular User).
Each user has options to view Routes, Stations, Log information, Profile and to Sign Out:
Administrator has special view dedicated to him which is to see the list of Users and to add them:
Displays railway routes as list of expandable elements that (once clicked) themselves display list of stations that are included in that route.
User can Add, Duplicate, Edit and Delete routes upon which modal popup window would be shown.
Additional available commands are Undo, Redo and Refresh.
Similar to Routes this view presents list of expandable items, but unlike in previous view, user can modify and delete Railway Platforms directly in the expanded table.
Displays Log information in table. User can see potential conflicts, information and errors in this view. Just like in Server log level can be modified in App.config
file
Each user can edit their first and last name.
As mentioned previously this application consists of Client
- Front End and Server
- Back End.
Both Front and Back end are then layered individually into sublayers such as Core
, Infrastructure
, Persistance
which share common purpose.
Represents combination of Domain and Application layers.
Domain layer - Contains all entities, enums, exceptions, types and logic specific to the domain.
Application 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.
This layer contains classes for accessing external resources such as file systems, web services, smtp, and so on. These classes are based on interfaces defined within the Core layer.
Represents implementation of interfaces from the Core layer related to Database. In this case it represents classes related to Entity Framework like DbContext, Migrations, Fluent API Configurations, Database Initialization (Seed) method, etc.
Holds logic related to GUI, which in this case is WPF Desktop Application. It depends on all of the other layers but none of them depend on Presentation layer. Purpose of clean architecture is to abstract this layer as much as possible so that it can be easily switchable.
In software engineering, a design pattern is a general repeatable solution to a commonly occurring problem in software design. A design pattern isn't a finished design that can be transformed directly into code. It is a description or template for how to solve a problem that can be used in many different situations.
Repository - Mediates between the domain and data mapping layers using a collection-like interface for accessing domain objects.
Unit of Work - Maintains a list of objects affected by a business transaction and coordinates the writing out of changes and the resolution of concurrency problems.
IRepository
and IUnitOfWork
interfaces can be found under Server.Core
and their implementation in Server.Persistance
class library.
Decorator pattern allows a user to add new functionality to an existing object without altering its structure. This type of design pattern comes under structural pattern as this pattern acts as a wrapper to existing class.
This pattern creates a decorator class which wraps the original class and provides additional functionality keeping class methods signature intact.
Example of decorator can be found in AuthLoggerDecorator
class which is used to decorate logging messages with username
attribute.
Command pattern is a data driven design pattern and falls under behavioral pattern category. A request is wrapped under an object as command and passed to invoker object. Invoker object looks for the appropriate object which can handle this command and passes the command to the corresponding object which executes the command.
This project introduces two types of commands:
ICommand
- Used by WPF for Binding.IUndoableCommand
- Used byCommandManager
for Undo / Redo functionality.
In class-based programming, the factory method pattern is a creational pattern that uses factory methods to deal with the problem of creating objects without having to specify the exact class of the object that will be created. This is done by creating objects by calling a factory method either specified in an interface and implemented by child classes, or implemented in a base class and optionally overridden by derived classes rather than by calling a constructor.
Example of Factory used in this project can be found in AuthServiceHostFactory
which is used to make ServiceHost
with customized headers used for authentification.
Facade pattern hides the complexities of the system and provides an interface to the client using which the client can access the system. This type of design pattern comes under structural pattern as this pattern adds an interface to existing system to hide its complexities.
This pattern involves a single class which provides simplified methods required by client and delegates calls to methods of existing system classes.
Example of Facade pattern for this project can be found in AuthServiceHostFactoryFacade
whose main goal is to simplify usage of AuthServiceHostFactory
.
Template method pattern is a behavioral design pattern that defines the program skeleton of an algorithm in an operation, deferring some steps to subclasses. It lets one redefine certain steps of an algorithm without changing the algorithm's structure.
This project uses Template Method pattern for Form ViewModels where base class would implement all of the required logic but OnSubmit
behavior would be abstracted away for child classes to implement.
The prototype pattern is a creational design pattern in software development. It is used when the type of objects to create is determined by a prototypical instance, which is cloned to produce new objects.
This project uses Prototype pattern by implementing provided ICloneable
interface. Example of class objects that use this are Model classes from Client.Core
. When they are passed to the Edit
Form View Model they need to be cloned so that passed class is not accidently modified by reference.
Copyright 2019 © DaniloNovakovic