Skip to main content

Getting started with AutoMapper

DTO

DTO stands for Data Transfer Object. DTOs are there for transfer data between the different application or different layers within a single application. You can look at them as dump bags of information. The purpose of existence is just getting that information to a recipient. So that recipient doesn't get anything other than they expect.

The major problem that I had with this DTO is mapping one object to another. Every place where I need to transfer my data using DTO, either I have to use parameterized constructor or new object initialize to inject the information (data) into it.

Recently I found this library called AutoMapper which made my code awesome. AutoMapper is a simple little library built to solve a deceptively complex problem "getting rid of code that mapped one object to another".

AutoMapper

It all started with Source Object and Destination Object to work with (well, that's obvious!). This works best as long as the names of the source type's members match up to the destination type's members. If you have "FirstName" in the source type, this will automatically be mapped to a destination type member called "FirstName". Don't worry even if you don' have match up names, still can be done.

Getting start with AutoMapper 

To perform this magic, have to cast a spell ;)

Like any other feature, AutoMapper has to configure before using it. Configure in the sense that you need to create your mappings. No mappings, No magic.

Initially, you are marking that source object should map with destination object with required members. After that when you ask AutoMapper to map source object to destination object. AutoMapper will do it for you. because it knows which member should map with what

Most important three points you need to know about configuration are How, When and Where.

How

AutoMapper provides two APIs: a static API or an instance API.

When

Instance API allows you to change the configuration at the run time. That caused many problems, so the new Static API does not allow you to do this. You have to configure everything in one place.

Where

Instance Mapper can be placed before you place map (Line before map will do). But Static Mapper should only happen once per AppDomain. That means the best place to put the configuration code is in application startup, such as the Global.asax file for ASP.NET applications.

Demo


// Source 
public class Person
{
    public string FirstName { get; set; }
}

// Destination 
public class PersonDTO
{
    public string FirstName { get; set; }
}

The static API (Recommended):

// Configuration 
Mapper.Initialize(cfg => {
    cfg.CreateMap<Person, PersonDTO>();
});


// Map to
PersonDTO personDTO = Mapper.Map<PersonDTO>(new Person());

the instance API:

// Configuration
var config = new MapperConfiguration(cfg => {
    cfg.CreateMap<Person, PersonDTO>();
});


// Create a mapper instance
var mapper = config.CreateMapper();
//// OR
var mapper = new Mapper(config);


// Map to
PersonDTO personDTO = mapper.Map<PersonDTO>(new Person());

May the force be with you! 

Comments

Popular Posts

SSAS: The Sort Order Specified For Distinct Count Records Is Incorrect.

Symptoms During a processing time of a cube that contains a distinct count measure, the process fails with the following error message: The sort order specified for distinct count records is incorrect Cause This is most likely caused by different sort order used on the data warehouse data set and the analysis service database data set. Resolution Modify the sort order of the data warehouse data set so that it will match with the analysis service database data set. Into the Depth  Navigate to the analysis database and start to process the desired database. When the processing begins, the Process progress window will pop up. Wait till the process gets failed. After the process failed, find the failing measure group and expand to the last node where you can see an SQL query. Double click on the query and view the details. This query gives you the exact order by the column which caused you this trouble.  Execute the query using the data warehouse datab...

ASP.NET Core 3.1 - Setting up React app with Typescript

With the release of .NET Core 3.1, I have decided to migrate one of my .NET core 2.1 solutions which contain ASP.NET core API project, React Web project (ASP.NET core project with react typescript template) and .NET Core Library project.  So I started the migration with the Library and API projects. Based on my experience, I think it was not a smooth migration due to the vast number of breaking changes but I managed to up and run both projects. Lastly, I have started to migrate the React ASP.NET core project. It was chaotic but I managed to up and run the project. Thought it worked I got some issues here and there so I decided not to continue with the same project rather create a new ASP.NET Core 3.1 React TypeScript template project. When you are going to create a new project, Visual Studio provided you a list of templates where you can pick desired Even though we have a project template for ASP.NET Core with React JS, there is no direct project templ...

Satellite Assembly in C#

Satellite Assemblies Resource files in Dot Net Resource files are typically used to store any resources in your Dot Net application. Resource file allows you to store images, icons, audio, files, strings and other types of resources. Of cause it is not mandatory to keep them inside a resource file. But when it comes to localization it is recommended to work with the resource file. localization Which means based on the user's language and culture change the application and the resources. How to archive localization with resources? Seems to be an impossible task. But to make the impossible possible, Dot Net provides you a special assembly called "Satellite Assembly" Satellite assemblies are assemblies that containing resources specific to a given language and culture. Using satellite assemblies, you can place the resources for different languages in different assemblies, and the correct assembly is loaded into memory only if the user selects to view the ...