This article explains how to execute the “Create Document”-step of AutoMerge manually in JavaScript. This allows to include this functionality in custom - applications (e.g. create documents via a CRM-button-click and save document to SharePoint )
This article covers both:
1) Calling the plugin
2) Handling the result
Attached you can find the full library for download.
Start the Create-Process
The “Create Document”- part of AutoMerge is installed as plugin in CRM. To trigger this plugin, you have to execute a “Retrieve Multiple”-request on the “MSCRM-ADDONS.com AMTrigger (logical name: ptm_mscrmaddonscomamtrigger)”-entity. It is important that the result-attributes-list contains the “ptm_FullXML”-attribute. It will contain information returned by the plugin.
In addition, the request must include two filter conditions.
The first condition needs to ensure that solely the record with the name “cmd_automerge” will be returned.
The second one is a pseudo-condition which is used to pass information to the plugin. This information has to be in XML-format and has to look like this:
<AMPluginParameters>
<EnableSingleDebugging>false</EnableSingleDebugging>
<MessageType>Create</MessageType>
<PrimaryEntityId>069E5412-84F6-E111-977B-00155DC8AE09</PrimaryEntityId>
<PrimaryEntityLogicalName>account</PrimaryEntityLogicalName>
<TemplateId>00BDBD7D-65DD-E111-BEC0-00155DC8AE09</TemplateId>
<SaveAs>docx</SaveAs>
<SaveLocation>1</SaveLocation>
<PrintTo></PrintTo>
</AMPluginParameters>
Description of parameter
• EnableSingleDebugging: Here you can define if this step should be debugged. Options: “true”, or “false”. It is recommended to always define it as “false”. If debugging is needed, activate it via the AutoMerge configuration.
• MessageType: Must be “Create”
• PrimaryEntityId: The Id of the record for which the merge process should be executed.
• PrimaryEntityLogicalName: The logical name of the starting entity.
• TemplateId: The Id of the template which should be used for the merge process.
• SaveAs: Defines the file format of the generated document (docx, doc, pdf,…).
• SaveLocation: There are two options. “0”: the document will be saved only in the “MSCRM-ADDONS.com User/Temp Settings”-entity. “1” the document will be saved in the “MSCRM-ADDONS.com User/Temp Settings”-entity and in File Share or SharePoint (depending on your setup of the DocumentsCorePack server configuration).
• PrintTo: If the generated document should be printed as well, define the path of the network printer here.
Example
The “Retrieve Multiple”-request looks like the following:
var filter = "<AMPluginParameters>";
filter += "<EnableSingleDebugging>false</EnableSingleDebugging>";
filter += "<MessageType>Create</MessageType>";
filter += "<PrimaryEntityId>069E5412-84F6-E111-977B-00155DC8AE09</PrimaryEntityId>";
filter += "<PrimaryEntityLogicalName>account</PrimaryEntityLogicalName>";
filter += "<TemplateId>00BDBD7D-65DD-E111-BEC0-00155DC8AE09</TemplateId>";
filter += "<SaveAs>docx</SaveAs>";
filter += "<SaveLocation>1</SaveLocation>";
filter += "<PrintTo></PrintTo>";
filter += "</AMPluginParameters>";
$ptm.retrieveMultiple("ptm_mscrmaddonscomamtriggerSet", "?$filter=(ptm_name eq 'cmd_automerge') or (ptm_FullXML eq '" + filter + "')&$select=ptm_FullXML", CreateDocumentFinished, CreateDocumentError);
CreateDoucmentFinished and CreateDocumentError specify the CallBack-function after executing the request.
Process the results
After the request is executed, you will receive a result from the plugin.
Successful result
A successful result message looks like the following:
„AM_6_17<>valid|533d31c2-72da-e311-a232-00155dc80d02|outgoingBytes:63510|”
• “AM_” is static text
• “6_17” is the plugin version
• “<>valid” is static text
• “533d31c2-72da-e311-a232-00155dc80d02” is the ID of the generated “MSCRM-ADDONS.com User/Temp Settings”-record. It contains the generated document in the “Notes”-section. If the document is stored in SharePoint or File share, you can find the full path to the document in the “Value”-attribute.
Unsuccessful result
An unsuccessful result message looks like this:
“ERROR:|CHECKLICENSE|SUCCEEDED|new AutoMerge|StartMerge|EmptyGUID||ErrorMerge|BeforeCreateDoc
AfterCreateDoc”
or like this:
"AM_13<>validERROR"
Example
Below you can find a function which handles the result. If the process was successful, the “documentId” will contain the Id of the created “MSCRM-ADDONS.com User/Temp Settings”-record. If not, an error message will be shown.
function CreateDocumentFinished(data, textStatus, XmlHttpRequest) {
if (data != null && data.length >= 1 && data[0].ptm_FullXML != undefined) {
var response = data[0].ptm_FullXML;
var indexOfPipe = response.indexOf("|");
var documentId = "";
if (indexOfPipe >= 0 && (response.indexOf("valid") != -1 || response.indexOf("trial") != -1) && response.toLowerCase().indexOf("error") == -1) {
documentId = response.substr(indexOfPipe + 1);
indexOfPipe = documentId.indexOf("|");
if (indexOfPipe != -1) {
documentId = documentId.substr(0, indexOfPipe);
}
}
else {
alert("ERROR: While creating document");
}
}
else {
alert("ERROR: While creating document");
}
}
Created “MSCRM-ADDONS.com User/Temp Settings”-record:
Image may be NSFW.
Clik here to view.
1: ID retrieved from the plugin. This ID references the mscrm-addons-temp record with the doucment attached
2: Link to the document on SharePoint: needed if you want to e.g. open the doucment from SharePoint
3: Attached document: Needed to process the temp-document
JavaScript-Example
Attached you can find the whole JavaScript-example. It uses the “ptm_GeneralJSFunctions.js” and "ptm_jquery1.4.1.min" web resources to trigger the plugin. They were imported during the installation of DocumentsCorePack server.
If you do not want to use this library, of course you can trigger the plugin with a standard HTTP request.