Example script that queries the Opportunity table
Summarize
Summary of Example script that queries the Opportunity table
This example script demonstrates how to query the Salesforce Opportunity table from ServiceNow using three custom spoke actions:Get All Opportunities,Get Opportunities for Account Id, andGet Opportunity Details. It is designed for ServiceNow customers who want to integrate Salesforce data into remote tables within their ServiceNow instance.
Show less
How the Script Works
The script is structured into three main parts, all wrapped in a try-catch block for robust error handling:
- Selecting a Spoke Action and Preparing Inputs: Based on parameters passed via
vquery, the script chooses the appropriate Salesforce spoke action to call. It supports querying a specific opportunity by Salesforce record ID, all opportunities related to a specific Salesforce account ID, or all opportunities in general. If the Salesforce account ID is undefined when required, the script logs an informational message and terminates early. - Calling the Spoke Action: Using the selected action and prepared inputs, the script invokes the Salesforce spoke action via
snfd.FlowAPI.executeAction, capturing the output for further processing. - Processing the Action Output: The script checks for errors in the response and throws an error if any are found. If successful, it iterates over the returned Salesforce opportunity records and maps key fields (such as Amount, CloseDate, Name, Probability, AccountId, StageName, Type, and Id) into the remote table rows. The Salesforce Opportunity record ID is assigned to the remote table’s
sysidfield to maintain proper list and form behavior within ServiceNow. Any informational message returned by the query is also displayed to the user.
Practical Benefits
- Enables seamless retrieval and display of Salesforce Opportunity data within ServiceNow remote tables.
- Supports flexible querying by opportunity ID, account ID, or retrieving all opportunities.
- Provides clear error and informational messages to assist administrators and users.
- Ensures proper synchronization between Salesforce record IDs and ServiceNow remote table entries for consistent data handling.
What Customers Should Expect
By implementing this script, ServiceNow customers can efficiently integrate Salesforce Opportunity data into their ServiceNow environment, empowering users to view and interact with Salesforce opportunities directly from ServiceNow interfaces. The script’s modular design allows easy adaptation for different query scenarios and ensures robust error handling to maintain a smooth user experience.
This example script queries the opportunity table using the Get All Opportunities, Get Opportunities for Account Id, and Get Opportunity Details custom actions.
- The first part selects the correct custom action and prepares inputs for it.
- The second part makes a call to the action.
- The third part processes the outputs of the action.
Selecting a spoke action and preparing the inputs
- Get All Opportunities
- Get Opportunities for Account Id
- Get Opportunity Details
v_query function argument./****** Choose action and prepare action inputs *****/
var action = null;
var inputs = {};
// look up opportunity by salesforce record id
if (v_query.isGet()) {
action = "get_opportunity_details";
inputs.salesforce_opportunity_record_id = v_query.getSysId();
// look up opportunities by salesforce account id
} else if (v_query.getParameter("u_sf_account_id")) {
if (v_query.getParameter("u_sf_account_id") == "undefined") {
gs.addInfoMessage(“Opportunities cannot be retrieved because “ +
“this “Account does not have associated “ +
“Salesforce Account. Please contact System “ +
“Administrator.");
return;
} else {
action = "get_opportunities_for_account_id";
inputs.salesforce_account_id = v_query.getParameter("u_sf_account_id");
}
// look up all opportunities
} else {
action = "get_all_opportunities";
}
Note that this script configures an information message if the Salesforce account is undefined when it’s required by the action. The undefined value comes from the relationship that is described in Using a related list to create the connection between the Customer Account and the Salesforce Opportunities.
When the Salesforce account is undefined, there’s nothing to query for in this case and the function returns without calling the spoke action.
Calling the spoke action
In this section of the script, call the action using the names of the Salesforce spoke and the selected action and store the outputs of the call.
/***** Call action *****/
var outputs =
sn_fd.FlowAPI.executeAction("sn_salesforce_spok." + action, inputs);
Processing the action output
In this section of the script, process the outputs starting with the check for errors.
/***** Process action outputs *****/
if (outputs.status != "Success") {
throw new Error(outputs.error_message);
}
If the query doesn’t return any errors, the script must process the returned records and add them as rows into the remote table. Map the Salesforce Opportunity fields into the remote table columns.
var opportunities = outputs.opportunities.data;
for (var i = 0; i < opportunities.length; i++) {
var opportunity = opportunities[i];
v_table.addRow({
"u_sf_amount": opportunity.Amount,
"u_sf_close_date": opportunity.CloseDate,
"u_sf_name": opportunity.Name,
"u_sf_probability": opportunity.Probability + "%",
"u_sf_account_id": opportunity.AccountId,
"u_sf_stage": opportunity.StageName,
“u_sf_type": opportunity.Type,
"sys_id": opportunity.Id,
});
}
Note that the Salesforce opportunity record Id is assigned to the remote table sys_id. This verifies that lists and forms for the remote table function properly and that we are able to extract the record Id using
v_query.getSysId() the next time that the remote table script is invoked.
Then display the information message if it was passed by the query.
if (outputs.info_message) {
gs.addInfoMessage(outputs.info_message);
}
Putting the remote table script sections together
The three sections of the script are included in the try-catch block to provide for error handling.
(function executeQuery(v_table, v_query) {
try {
// place code here from: <Selecting a spoke action and preparing the inputs>
// place code here from: <Calling the spoke action>
// place code here from: <Processing the action output>
} catch (error) {
gs.addErrorMessage("Error retrieving Salesforce Opportunities. “ +
“Please contact System Administrator.");
gs.addErrorMessage("System Error: " + error.message);
}
})(v_table, v_query);