AutoMapperConfiguration.Reflection 1.0.0

Automatically creates an AutoMapper profile by Reflection.

Install-Package AutoMapperConfiguration.Reflection -Version 1.0.0
dotnet add package AutoMapperConfiguration.Reflection --version 1.0.0
<PackageReference Include="AutoMapperConfiguration.Reflection" Version="1.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add AutoMapperConfiguration.Reflection --version 1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: AutoMapperConfiguration.Reflection, 1.0.0"
#r directive can be used in F# Interactive, C# scripting and .NET Interactive. Copy this into the interactive tool or source code of the script to reference the package.
// Install AutoMapperConfiguration.Reflection as a Cake Addin
#addin nuget:?package=AutoMapperConfiguration.Reflection&version=1.0.0

// Install AutoMapperConfiguration.Reflection as a Cake Tool
#tool nuget:?package=AutoMapperConfiguration.Reflection&version=1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.

AutoMapper.ReflectionConfiguration

Automatically creates an AutoMapper profile by Reflection and provides an easy way to register your mappings.

How it works?

By installing this package you will receive three interfaces to work with - IMapTo, IMapFrom and IHaveCustomMappings. They will give you all you need to register your mappings. During application start up all classes that implements this three interfaces will be collected and registered in new AutoMapper profile.

How to use?

  • First you need to register AutoMapper and provide all assemblies that contains mapping classes. This extension method will register your assemblies and will register AutoMapper into ASP.NET IOC Container that means you can inject IMapper interface whatever its needed.
public void ConfigureServices(IServiceCollection services)
{
    // Rest of registrations here.

    services.AddAutoMapper(typeof(ErrorViewModel).GetTypeInfo().Assembly, typeof(UserServiceModel).GetTypeInfo().Assembly);
}

After this all you need to do is to write your C# classes and specify how they should be mapped. This will be easy with IMapTo and IMapFrom interfaces. All you need to do is to implement them and specify destination/source class. In case you have some difference in property naming or want to settup some thing custom mapping you can do this by implementing IHaveCustomMappings interface. This will enforce you to implement a method in witch you can do wathever its needed. Here is some examples:

  • IMapFrom
public class UserDetailsViewModel : IMapFrom<User>
{
    public string Id { get; set; }
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public string UserName { get; set; }
}
  • IMapTo
public class AddUserInputModel : IMapTo<User>
{
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public string UserName { get; set; }
}
  • IHaveCustomMappings
public class UserDetailsViewModel : IMapFrom<User>, IHaveCustomMappings
{
    public string Id { get; set; }
    public string FullName { get; set; }
    public string UserName { get; set; }

    public void CreateMappings(IProfileExpression configuration)
    {
        configuration.CreateMap<User, UserDetailsViewModel>()
            .ForMember(x => x.FullName, cfg => cfg.MapFrom(y => y.FirstName + y.LastName));
    }
}

AutoMapper.ReflectionConfiguration

Automatically creates an AutoMapper profile by Reflection and provides an easy way to register your mappings.

How it works?

By installing this package you will receive three interfaces to work with - IMapTo, IMapFrom and IHaveCustomMappings. They will give you all you need to register your mappings. During application start up all classes that implements this three interfaces will be collected and registered in new AutoMapper profile.

How to use?

  • First you need to register AutoMapper and provide all assemblies that contains mapping classes. This extension method will register your assemblies and will register AutoMapper into ASP.NET IOC Container that means you can inject IMapper interface whatever its needed.
public void ConfigureServices(IServiceCollection services)
{
    // Rest of registrations here.

    services.AddAutoMapper(typeof(ErrorViewModel).GetTypeInfo().Assembly, typeof(UserServiceModel).GetTypeInfo().Assembly);
}

After this all you need to do is to write your C# classes and specify how they should be mapped. This will be easy with IMapTo and IMapFrom interfaces. All you need to do is to implement them and specify destination/source class. In case you have some difference in property naming or want to settup some thing custom mapping you can do this by implementing IHaveCustomMappings interface. This will enforce you to implement a method in witch you can do wathever its needed. Here is some examples:

  • IMapFrom
public class UserDetailsViewModel : IMapFrom<User>
{
    public string Id { get; set; }
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public string UserName { get; set; }
}
  • IMapTo
public class AddUserInputModel : IMapTo<User>
{
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public string UserName { get; set; }
}
  • IHaveCustomMappings
public class UserDetailsViewModel : IMapFrom<User>, IHaveCustomMappings
{
    public string Id { get; set; }
    public string FullName { get; set; }
    public string UserName { get; set; }

    public void CreateMappings(IProfileExpression configuration)
    {
        configuration.CreateMap<User, UserDetailsViewModel>()
            .ForMember(x => x.FullName, cfg => cfg.MapFrom(y => y.FirstName + y.LastName));
    }
}

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version History

Version Downloads Last updated
1.0.0 360 5/8/2020