make code wait for async 8.2

The async function to wait

function getSetting (settingName)
var req = new XMLHttpRequest();

return new Promise(function (resolve, reject) {

    // Setup our listener to process compeleted requests
    req.onreadystatechange = function () {

        // Only run if the request is complete
        if (req.readyState !== 4) return;

        // Process the response
        if (req.status >= 200 && req.status < 300) {
            // If successful
            ( req      );
        } else {
            // If failed
                alert ("multiple setting with the name :" + settingName)

    };"GET", Xrm.Page.context.getClientUrl() + "/api/data/v8.2/query, false);
req.setRequestHeader("OData-MaxVersion", "4.0");
req.setRequestHeader("OData-Version", "4.0");
req.setRequestHeader("Accept", "application/json");

Add clickable button in the form

I do it via webressource
      * {
                    margin: 0;
                    padding: 0;

                    background-color: #00B3D9;
                    color: #FFFFFF;
                    font-family: Segoe UI, Tahoma, Arial;
                    font-size: 14px;
                    padding: 5px 10px 5px 10px;
                    margin: 0px 4px 3px 1px;
                    width: 100px;
                    text-overflow: ellipsis;
                    display: inline-block;
                    text-align: center;
                    overflow: hidden;
                    white-space: nowrap;
                    border-radius: 16px;
                    border :none;
                    float : left;
                    border-bottom : none;

    <body onload="LoadFormTabs()" onfocusout="parent.setEmailRange();…

CRM dynamics V9 wait Async web API to contiue code


here is how to do an async call from v9

here is the structur of a call

function azerty ()
  Xrm.WebApi.retrieveMultipleRecords("teams", "?$select=name,teamid&$filter="+clause).then(
      function success(result)
    //Your COde here part A

        function (error)

 //other code here; part b //Yuou want this code to be executed after part A
because the webapi call is assync the part B would be executed before part A


then if you want to execute part B after part A here is how to do
In green what is change to make it work

async function azerty ()
//Some code

await myPartAcode();



function myPartAcode()

return new Promise(resolve => { {

  Xrm.WebApi.retrieveMultipleRecords("teams", "?$select=name,teamid&$filter="+clause).then(
      function success(result)
            // perform operations on…

Remap crm user to ActiveDirectory User

I imported an organization and I mapped only system user

CRM : 2016 V8.2 OnPremise

Then at the end only mapped User can connect To CRM while normal user are still visible in CRM systemUser.

To see if they are mapped you can use

select * from MSCRM_CONFIG.[dbo].[SystemUserOrganizations] org
join SystemUserBase users on (users.SystemUserId = org.CrmUserId)

then to remapp normal user I did

1/ disable user + save
2/ change the logon user (I added a s after) + Save
3/ change back the logon by the correct logon user (remove the S)
4 enable the user

re do the query,
select * from MSCRM_CONFIG.[dbo].[SystemUserOrganizations] org
join SystemUserBase users on (users.SystemUserId = org.CrmUserId)

you will see the user is mapped

retrieve queue item filtered by object

I had to look for that because when reactivating a case i Hade an error that say that multiple queueitem exist.

if you want to retrieve the queue item by case/email/... knowing the guid of the case/email/...

here is the query

{{webapiurl}}/queueitems?$top=3&$filter=_objectid_value eq BA774537-B561-E911-80E7-005056B22A06

after i retrieve the queue item id and i delete it


Update Email with web API

when you receive an email and it s wrong resolve because of human or computer
you need to correct it.

For that i set the email activity in draft with dynamics power pane (chrome extention)

and after I apply this in PATCH mode with postMan

{ "statuscode":4,
  "email_activity_parties" :  [
            "partyid_lead@odata.bind" : "/leads(87701058-3C67-E911-80E7-005056B22A06)",
            "participationtypemask" : 1
            "partyid_queue@odata.bind" : "/queues(7A5AC7BE-BE0C-E411-8890-AC162DAC65CC)",
            "participationtypemask" : 2

Quick Create, open created record

The idea is , when you create a record with quick create, to redirect directly on created record. sometime you have a yellow button on the top right but in my case the yeallow button with the link to the new created record did not appear.
then I decide to redirect with JS

then yes we have function in a function

function MyBaseFunction()

 Xrm.Utility.openQuickCreate("incident", recordId, parameters).then

function (lookup)
function (error)

    function successCallback(lookup) {
        setTimeout(function () {; }, 1000);
        Xrm.Utility.openEntityForm("incident",, null, null);
        setTimeout(function () {; }, 1000);

    // **** Function called on error.
    function errorCallback(e) {  // *** No new contact created, which is an error we can ignore!
        alert("Error: " + e.errorCode + "…