data:image/s3,"s3://crabby-images/19ab0/19ab060a514b07138b6e1f8b56cb9d0fa45eb0dd" alt=""
When I entered the world of PCF controls, I was looking for a way to quickly and easily debug PCFs within Dynamics 365. While searching, I stumbled upon Diana Birkelbach’s blog. She describes how to debug PCFs with Fiddler AutoResponder. Unfortunately, this tool is only available for Windows, and the version available for MacOS (Fiddler Everywhere) I found to be not user-friendly and only available as a trial version.
After searching, I found the tool Proxyman, which looks extremely user-friendly and is also free to use up to 1 rule, which is sufficient for me for now.
Configure Proxyman
Install the SSL certificate from Proxyman to be able to inspect SSL traffic. You can do this at Settings > General.
data:image/s3,"s3://crabby-images/d59cd/d59cde798f8c43ee62b298067cc23b3dc89fd2d3" alt=""
data:image/s3,"s3://crabby-images/10e71/10e713c6a8778afafde41ff3befac05b496bab7c" alt=""
After the installation is complete, you need to install the Proxy Helper Tool, which can be found in the Advanced tab.
data:image/s3,"s3://crabby-images/60e0b/60e0b57b401d18f66deb61acbede9503841a21f5" alt=""
Now that Proxyman can inspect SSL traffic, we can begin by adding rules. First, go to Tools > SSL Proxying list and add the Dynamics environment where we want to debug. Click on + and select Add App/Domain.
data:image/s3,"s3://crabby-images/e668c/e668cffa0664dfa13ebf5a5054b10a60e914cfad" alt=""
Add the URL of the environment where we want to debug, for example, example.crm4.dynamics.com.
data:image/s3,"s3://crabby-images/dd1e5/dd1e5820551c81b34524b34888f92885b0dd195c" alt=""
Now that this is configured, we can set the Allow list via Tools > Allow list. We do this so that Proxyman does not process all the traffic from Dynamics but only the requests from the PCF control. This is done using a RegEx. Modify the following RegEx below and use it for the Matching Rule.
https:\/\/example\.crm4\.dynamics\.com(\/.*?)(\/css)?(\/|cc_)PCFNAMESPACE\.PCFCONSTRUCTOR\.(.*)
data:image/s3,"s3://crabby-images/edc69/edc6963d1e71b5cd527f2aaf35920227148e97d2" alt=""
You can test your rule to make sure it works correctly.
Now that the allow list is set, let’s move on to the final step. Go to Scripting > Script list and add a new rule.
Provide a recognizable name and fill in the following under the URL:
(.*?)(\/css)?(\/|cc_)PCFNAMESPACE.PCFCONSTRUCTOR.(.*)
For the script, you can use the following code, make sure to adjust the RegEx and file path:
async function onResponse(context, url, request, response) {
response.headers["Cache-Control"] = "no-cache, no-store, must-revalidate"; // So you don't have to refresh the cache everytime while debugging
const regex = /(.*?)(\/css)?(\/|cc_)PCFNAMESPACE.PCFCONSTRUCTOR.(.*)/;
const match = url.match(regex);
if (match && match[4]) {
response.bodyFilePath = "/path/to/your/PCF-Control/out/controls/" + match[4];
}
return response;
}
You can also test your scripting rule before saving.
data:image/s3,"s3://crabby-images/4c225/4c2258922b08934de79a3892a57aa6d4e3fcc111" alt=""
Once your script is saved and activated, you can enable Proxyman and start debugging!
data:image/s3,"s3://crabby-images/54035/540352cd7b668faa970ebbdb454602172d372f57" alt=""
Happy debugging!
Leave a Reply