Profiles

Other topics

Basic Profile

Profiles permit the programmer to organize maps into classes, enhancing code readability and maintainability. Any number of profiles can be created, and added to one or more configurations as needed. Profiles can be used with both the static and instance-based APIs.

public class User
{
    public int Id { get; set; }
    public string Username { get; set; }
    public string Password { get; set; }
    public string DisplayName { get; set; }
    public string Email { get; set; }
    public string PhoneNumber { get; set; }
}

public class UserViewModel
{
    public string DisplayName { get; set; }
    public string Email { get; set; }
}

public class MappingProfile : Profile
{
    public MappingProfile()
    {
        CreateMap<User, UserViewModel>();
    }
}

public class Program
{
    static void Main(string[] args)
    {
        Mapper.Initialize(cfg => {
            cfg.AddProfile<MappingProfile>();
            //cfg.AddProfile(new MappingProfile()); // Equivalent to the above
        });

        var user = new User()
        {
            Id = 1,
            Username = "jdoe",
            Password = "password",
            DisplayName = "John Doe",
            Email = "[email protected]",
            PhoneNumber = "555-123-4567"
        };
        
        var userVM = Mapper.Map<UserViewModel>(user);

        Console.WriteLine("DisplayName: {0}\nEmail: {1}", userVM.DisplayName, userVM.Email);
    }
}

Loading all profiles in an assembly

Often it is useful to be able to load all of the profiles in one or more assemblies into a configuration. AutoMapper provides the method AddProfiles method, which has several overloads that allow profiles to be loaded by passing the Assembly, specifying the assembly name, or specifying a type contained in the assembly. Only classes inheriting from AutoMapper.Profile will be located and added to the configuration.

Load all profiles in an assembly by specifying the name of the assembly:

Mapper.Initialize(cfg => {
    cfg.AddProfiles("MyApplication.Core", "MyApplication.Web");
});

Load all profiles in an assembly by specifying a type from the assembly:

Mapper.Initialize(cfg => {
    cfg.AddProfiles(typeof(Student), typeof(Course));
});

Load all profiles in the current assembly:

Mapper.Initialize(cfg => {
    cfg.AddProfiles(Assembly.GetExecutingAssembly());
});

Syntax:

  • public void AddProfiles(params string[] assemblyNamesToScan)
  • public void AddProfiles(params Assembly[] assembliesToScan)
  • public void AddProfiles(params Type[] typesFromAssembliesContainingProfiles)
  • public void AddProfiles(IEnumerable<string> assemblyNamesToScan)
  • public void AddProfiles(IEnumerable<Assembly> assembliesToScan)
  • public void AddProfiles(IEnumerable<Type> typesFromAssembliesContainingProfiles)

Parameters:

ParameterDetails
assemblyNamesToScanAssembly names containing profiles to load and scan.
assembliesToScanAssemblies containing profiles to scan.
typesFromAssembliesContainingProfilesTypes from assemblies containing profiles to load and scan

Contributors

Topic Id: 5729

Example Ids: 20270,20271

This site is not affiliated with any of the contributors.