Tuesday, January 10, 2023

Using Power Platform Data Integrator to integrate F&O Delivery Address Location with CE Account

In this article, we will see how to Integrate D365 F&O Customer Delivery Address Location with D365 CE  Account via Power Platform's Data Integrator. This is going to be a one-way integration from F&O to CE, but you can expand the solution to be bi-directional.

Here is the recording of this Demo:






Low-Code options within the MS ecosystem for the Integration layer:

  1. Dual-Write
  2. Power Platform Data Integrator (approach used in this Demo)
  3. Data Events through Virtual Entity and Power Automate

Limitation in Dual-Write based on my trial:


In F&O Location is Global data and in CE Account is Business Unit specific, this case seems to be not a fit for the Dual-Write framework.  

On trying to save the table map in Dual-Write, this is the error message I received:

Project validation failed. [DIPV1002] ST5CustDeliveryAddressEntity or AX is a cross-company entity that doesn't have primary company field set and accounts of CRM is a company-specific entity with primaryCompanyField set to msdyn_company.cdm_companycode. Please make sure the entities are both cross-company or company-specific entities.

Looks like it is a pre-requisite in Dula-Write, that either both the entities need to be Global or Legal entity specific.

So, I moved on to Power Platform's Data Integrator approach.


Power Platform's Data Integrator approach:

Environments Set-up:

  • I have setup Contoso demo data in F&O 
  • I have setup CE Dataverse to be blank data.
  • Create USMF BU in Dataverse manually (or go through Dual-Write setup which would create this for you).
  • Manually Created a new Customer "San-1" in F&O
        



  • Manually Created a new account "San-1" in CE
            




Security in Dataverse:

In Power Platform, make sure in each Business Unit the default Team has System Admin role. Integration layer uses the default Team of the BU in context.

At the minimum, do this for root BU and USMF BU




F&O Custom Data Entity:

In F&O, I created a custom Data Entity ST5CustDeliveryAddressEntity to expose Customer Delivery Addresses:

Data sources used:

  • LogisticsPostalAddress
  • LogisticsLocation
  • DirPartyLocation
  • CustTable

At the minimum, we would expose the following fields:

  • LocationId (from LogisticsLocation)
  • Description (from LogisticsLocation)
  • AccountNum (from CustTable)
Key: LocationId, ValidFrom

Range: On DirPartyLocation.IsRoleDelivery set to true

Verify the data exposed by OData API, it should render only Customer Delivery Address Locations:

https://<FO instance name>.axcloud.dynamics.com/data/ST5CustDeliveryAddresses

Now Add new Delivery Address with name "Chicago Del-3" on the Customer San-1


Verify that Delivery Address with name "Chicago Del-3" shows up in the OData API output:

https://<FO instance name>.axcloud.dynamics.com/data/ST5CustDeliveryAddresses?$filter=AccountNum%20eq%20%27San-1%27



Data Integrator Project in Power Platform Admin Portal:

In Power Platform Admin Portal -> Data Integration:

  • Create a new Connection Set, to establish a connection between F&O instance and CE instance
    • Here we would select the Organization to be USMF
  • Create a new Project (name could be FO to CE OOB)
    • Associate the Connection set created earlier
    • Select the template to be "Fin and Ops to Sales"
    • Select Organization to be USMF



  • Click the Project created -> Add Task -> 
    • Task Name: FO Delivery Address to CE Account
    • F&O Table: ST5CustDeliveryAddressEntity 
    • CE Table: Accounts
    • Org: USMF
  • Click the Task to add field mappings as per below screenshot

            


  •     Click Filter icon on Source, add following filter:  ((ACCOUNTNO eq "San-1"))
               This way integration fetches only Delivery Addresses related to San-1 customer, to keep the demo simple. You could also use "Advanced query and filtering" feature, which is more like Power Query.

  • Save the Task and Run the Project manually

            



  • Go to Execution History Tab, the run instance would be in status running. 
  • After couple of mins the status would change to Completed
        
        


   



Now go CE All Accounts page, we would see the new Account with name "Chicago Del-3"




Hope this blog comes in handy for the community. 

In the later series, I may try to come up with a similar demo using Data Events (via Virtual Entity) approach.

References:

Data Integrator: Integrate data into Microsoft Dataverse - Power Platform | Microsoft Learn


No comments:

Post a Comment