Logic Apps with On-Premise Dynamics 365
Summary
In this post I’ll explain how to connect to a Microsoft Dynamics 365 on-premise environment with Azure Logic Apps.
Three key items are required:
- Azure Subscription
- Installation of the on-premise gateway
- Firewall rules for inbound/outbound configured correctly
Assuming all the above have been configured/installed, here are the steps:
Select HTTP with Azure AD activity. The Action here is Invoke an HTTP request. For simplicity, I have selected my trigger as scheduled recurrence.
data:image/s3,"s3://crabby-images/1ae7c/1ae7c7e468dea46db586ac8b813936c9fdab9f1d" alt=""
Next select the Connect via on-premise data gateway. This should be available if it was installed correctly.
data:image/s3,"s3://crabby-images/9e216/9e216a6bcbe7da1580c41fee3d7cb3c10767f61b" alt=""
Complete the fields as required. The Base Resource URL is the Web API URL
data:image/s3,"s3://crabby-images/63053/63053824b65b2c77ac9154df71bc83451e87db4f" alt=""
The final screen should look as follows:
data:image/s3,"s3://crabby-images/c427a/c427ad011bbe7dd860b9fec2656f1b7a29c7db62" alt=""
The code behind the Logic Apps activity.
{
"definition": {
"$schema": "https://schema.management.azure.com/providers/Microsoft.Logic/schemas/2016-06-01/workflowdefinition.json#",
"actions": {
"Invoke_an_HTTP_request": {
"inputs": {
"body": {
"method": "GET",
"url": "http://winserver2016a/eax360Sit/api/data/v9.0/accounts"
},
"host": {
"connection": {
"name": "@parameters('$connections')['webcontents']['connectionId']"
}
},
"method": "post",
"path": "/codeless/InvokeHttp"
},
"runAfter": {},
"type": "ApiConnection"
}
},
"contentVersion": "1.0.0.0",
"outputs": {},
"parameters": {
"$connections": {
"defaultValue": {},
"type": "Object"
}
},
"triggers": {
"Recurrence": {
"recurrence": {
"frequency": "Minute",
"interval": 3
},
"type": "Recurrence"
}
}
},
"parameters": {
"$connections": {
"value": {
"webcontents": {
"connectionId": "/subscriptions/600c20c7-54ee-4817-8cc1-b1d6782ffaaf/resourceGroups/PROD-LogicApps-Integration/providers/Microsoft.Web/connections/webcontents",
"connectionName": "webcontents",
"id": "/subscriptions/600c20c7-54ee-4817-8cc1-b1d6782ffaaf/providers/Microsoft.Web/locations/uksouth/managedApis/webcontents"
}
}
}
}
}
Running the Logic Apps should now give you a successful result.
data:image/s3,"s3://crabby-images/beeae/beeaefe81664c71c20f3b8f9d32c5031676d4981" alt=""
You can now use the result for other business logic. Here I am routing data from an on-premise Dynamics 365 to an Dynamics 365 CE online environment.
data:image/s3,"s3://crabby-images/ea4fb/ea4fb7404555ad5f93839cc374efe1bf8241a2c2" alt=""
Logic Apps does not have NTLM support, so you can’t make HTTP requests using the HTTP activity to Dynamics 365 on-premise. However using the data gateway makes consuming CRM data possible.
At the time of writing, I wasn’t able to research a way to trigger based on a data gateway activity.
Hope this helps.