Skip to content

A convention-based entity to object mapper (table to object) plus additional data utilities for Dateverse client applications and plugins plugin development.

License

Notifications You must be signed in to change notification settings

emerbrito/dataverse-extensions-data

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

EmBrito.Dataverse.Extensions.Data

Nuget GitHub Workflow Status

Data utilities for Dateverse client applications and plugin development.

Entity Mappings

Performs data transformation between an entity (table) and a business object (such as a DTO). A common use case is when you need to map an entity to a dto, serialize and send it to an external API. In this document:

Basic Usage

To perform data mapping and transformation your DTO must extend the EntityMapper class. Mapping is done by decorating each mapped property with a corresponding attribute.

A simple example:

public class AccountDto : EntityMapper<AccountDto>
{
    [FromStringColumn("name")]
    public string Name { get; set; }

    [FromOptionSetColumn("industrycode", formattedValue: true)]
    public string IndustryCode { get; set; }

    [FromCurrencyColumn("openrevenue")]
    public decimal? Revenue { get; set; }

    [FromOptionSetColumn("statecode")]
    public int State { get; set; }

    public AccountDto(Entity entity) : base(entity)
    {
    }
}

In this example an instance of the DTO is created from an account entity and then serialized to JSON:

Entity account = crmServiceClient.Retrieve("account", accountId, new ColumnSet(true));
AccountDto dto = new AccountDto(account);

// serializing the mapped object
string jsonString = JsonSerializer.Serialize(dto);

The JSON should look like this:

{
    "Name": "Contoso",
    "IndustryCode": "Business Services",
    "Revenue": 3000000,
    "AccountState": 1
}

See the following sections for additional details on data transformation.

Using Columns Formatted Value

Some dataverse columns such as numbers, dates and currency have built in support for formatted values. The formatted value of an option set (choice) is its label.

The use the formatted value, map to a string property and set the formattedValue parameter to true.

// returns the option set label
[FromOptionSetColumn("statecode", formattedValue: true)]
public string Status { get; set; }

// returns the formatted date
[FromDateTimeColumn("modifiedon", formattedValue: true)]
public string DateModified { get; set; }

// returns the formatted currency value
[FromCurrencyColumn("annualrevenue", formattedValue: true)]
public string Revenue { get; set; }

Applying String Format

Some attributes will support a string format parameter. When provided, this format will be applied to the output string. More information on supported formats can be found here: How to format numbers, dates, enums, and other types in .NET

// sample output: 2023-10-25
[FromDateTimeColumn("modifiedon",format: "yyyy-MM-dd")]
public string DateModified { get; set; }

// sample output: 
[FromCurrencyColumn("annualrevenue", format: "C3")]
public string Revenue { get; set; }

Mapping Multiple Choice Columns

The output of a multiple choices columns is controlled by the attribute paramaters and the property type.

// The examples using a List<T> (int or string) could also be replaced with arrays of the equivalent type.

// Returns a list of numbers with the value from each selection.
[FromOptionSetCollectionColumn("new_subscription")]
public List<int> Subscriptions { get; set; }

// Returns a list of strings with the numeric value from each selection.
[FromOptionSetCollectionColumn("new_subscription")]
public List<string> Subscriptions { get; set; }

// Returns a list of strings with the label from each selection.
[FromOptionSetCollectionColumn("new_subscription", formattedValue: true)]
public List<string> Subscriptions { get; set; }

// Returns a comma separated string with the numeric value of all selected items.
[FromOptionSetCollectionColumn("new_subscription")]
public string Subscriptions { get; set; }

// Returns a comma separated string with the label from all selected items.
[FromOptionSetCollectionColumn("new_subscription", formattedValue: true)]
public string Subscriptions { get; set; }

Mapping Entity Collection Columns

Some columns such as Activity Party returns an entity collection. The output will always be the ID property of each entity which could be represented by the following types:

  • Guid[]
  • List
  • string[] (Guid as string)
  • List (Guid as string)
[FromEntityCollectionColumn("to")]
public List<Guid> EmailTo { get; set; }

Mapping Entity Reference Columns

Entity reference columns can output their id as Guid or string and their formatted value (the primary name column of the corresponding entity).

// Outputs entity reference id
[FromEntityReferenceColumn("parentaccountid")]
public Guid? ParentAccount { get; set; }

// Outputs entity reference id as string
[FromEntityReferenceColumn("parentaccountid")]
public string ParentAccount { get; set; }

// Outputs entity reference formatted value (the primary name column)
[FromEntityReferenceColumn("parentaccountid", formattedValue: true)]
public string ParentAccount { get; set; }

Mapping Entity Reference Collection Columns

Entity reference collection columns can output their id as Guid or string and their formatted value (the primary name column of the corresponding entity).

  • Guid[]
  • List
  • string[] (Guid as strings)
  • List (Guid as strings)
  • List (primary name when formattedValue is true)
  • string (comma separate list of primary name when formattedValue is true)

Custom Converters

You can apply custom data transformation to handle specific business scenarions. Form example, you may need to return different labels for an option set than what you get from formatted values.

public class AccountDto : EntityMapper<AccountDto>
{
    public AccountDto(Entity entity) : base(entity)
    {
    }
    
    [FromOptionSetColumn("accounttype")]
    public string AccountType { get; set; }

    // Ovveride the Configure method to specify custom converter for specific fields
    protected override void Configure(EntityMapperOptions options)
    {
        options.AddConverter("accounttype", AccountTypeConverter);
    }

    object AccountTypeConverter(MappedProperty mappingInfo, Entity entity)
    {
        var choice = entity.GetAttributeValue<OptionSetValue>("accounttype");        
        return choice.Value == 2 ? "Premium" : "Standard"        
    }

}

Data Mapping Attributes

The attribute name is self explanatory and should match the column type you are mapping from. The property type will determine the desired output, or the type you are mapping to.

Below is a list of all available attributes the the supported output type.

Columns mapped to a string property may output their primitive values, the column formatted value from the dataverse or a formatted string when a format parameter is provided. Support for each option is based on the attribute type. A formattedValue paramter will be available in the attribute when supported.

FromBooleanColumn

  • Boolean
  • Integer
  • String (will display true, false or the option set label)

FromCurrencyColumn

  • Decimal
  • String

FromDateTimeColumn

  • DateTime
  • String

FromDecimalColumn

Conversion to other numeric types or boolean will be performed based on the value. If the value cannot be converted an exception will be thrown.

  • Bool
  • Decimal
  • Double
  • Float
  • Int
  • String

FromDoubleColumn

Conversion to other numeric types or boolean will be performed based on the value. If the value cannot be converted an exception will be thrown.

  • Bool
  • Decimal
  • Double
  • Float
  • Int
  • String

FromEntityCollectionColumn

  • Array
  • Array (Guid will be converted to string)
  • List
  • List (Guid will be converted to string)

FromEntityReferenceCollectionColumn

  • Array
  • Array (Guid will be converted to string)
  • List
  • List (Guid will be converted to string)

FromEntityReferenceColumn

  • Guid
  • String

FromImageColumn

  • byte[] (the original byte array returned by as the column value).
  • String (a base64 string representing the byte[])

FromIntegerColumn

Conversion to other numeric types or boolean will be performed based on the value. If the value cannot be converted an exception will be thrown.

  • Bool
  • Decimal
  • Double
  • Float
  • Int
  • String

FromOptionSetCollectionColumn

  • Array
  • Array (With numeric values or option set labels)
  • List
  • List (With numeric values or option set labels)

FromOptionSetColumn

Conversion to other numeric types besides decimal, or boolean will be performed based on the value. If the value cannot be converted an exception will be thrown.

  • Bool
  • Decimal
  • Double
  • Float
  • Int
  • String (numeric value or option set label)

FromStringColumn

Conversion to numeric types, boolean or DateTime will be performed based on the value. If the value cannot be converted an exception will be thrown.

  • Bool
  • Decimal
  • DateTime
  • Double
  • Float
  • Int
  • String

FromUniqueIdentifierColumn

  • Guid
  • String (Guid converted to a string)

Dataverse Column Type to .net Types

The following table is meant for reference only. It indicates how the dataverse columns are mapped to .net types by the PowerPlatform SDK. It also indicates the column types that have native support for formatted values.

Column Type .net type Formatted Value Support1
Activity Party EntityCollection2
Auto Number string
Currency Money Yes
Customer EntityReference Yes
Date and Time DateTime Yes
Decimal decimal Yes
Duration Int32 Yes
File Guid
Float Double Yes
Image byte[]
Language Code Int32 Yes
Lookup EntityReference Yes
Multiple Lines of Text string
MultiSelect Option Set (Choice) OptionSetValueCollection Yes
Option Set (Choice) OptionSetValue Yes
Owner EntityReference Yes
Single Line of Text string
Status OptionSetValue Yes
Status Reason OptionSetValue Yes
Time Zone Int32 Yes
Ticker Symbol string
Two Options bool Yes
Unique Identifier Guid
Whole Number Int32 Yes

1 Whether a string representing a formatted value is also returned by query expressions. 2 An Activity Party column will return an entity collection of actvityparty. The partyid column of each returned entity will contain an EntityReference to the actual record.

About

A convention-based entity to object mapper (table to object) plus additional data utilities for Dateverse client applications and plugins plugin development.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages