Agent submitting a case
Summarize
Summary of Agent submitting a case
This use case demonstrates how agents can submit complaint cases on behalf of known customers within ServiceNow by integrating with a remote bank application. Agents access customer and financial account information directly from the complaint form through REST API calls to external endpoints, streamlining case creation while ensuring customer data is saved locally in ServiceNow.
Show less
Key Features
- Customer Account Lookup: From the complaint form, agents click an Account Search button to open a pop-up where they can search for customer accounts using customizable search parameters that interface with external banking systems via REST APIs.
- Data Integration and Storage: The form scripts use RESTMessageV2 to call bank endpoints
/api/getConsumerDetailsand/api/getFinancialAccounts, retrieving consumer and mortgage account details which are then stored in the ServiceNowcsmconsumerandfinancialaccounttables respectively using GlideRecord API. - Complaint Case Completion: After selecting and populating account information, agents manually add case details and submit the complaint, ensuring all relevant customer and financial data is captured within ServiceNow.
Practical Implementation Details
- The remote bank application must expose the required REST endpoints returning consumer and financial account data in JSON format.
- ServiceNow developers can leverage the provided JavaScript example to implement the integration, which includes fetching consumer data, storing it locally, then retrieving and saving associated financial accounts.
- Using the RESTMessageV2 API enables secure and efficient communication with external systems, while GlideRecord API handles local database updates.
- Populating the complaint form with retrieved data improves agent efficiency and ensures data consistency.
Benefits for ServiceNow Customers
- Enables agents to quickly access accurate customer and mortgage account information without leaving ServiceNow, improving case handling speed and accuracy.
- Ensures customer data synchronization between ServiceNow and external banking systems.
- Facilitates seamless integration with core banking software providers, enhancing the ServiceNow complaint management process for financial organizations.
This use case illustrates how to enable an agent to submit a case for a known customer.
In this scenario, from within an FSO complaint form, an agent looks up a customer's account information, which is located on a remote bank application. Once located, it appears within the complaint form and the agent then manually fills in the case details related to the customer's mortgage account and save the complaint case. In the background, the form script saves the customer details and financial account information locally on the ServiceNow instance.
- Consumer [csm_consumer]: Contains customer record.
- Loan Account [sn_bom_loan_account]: Contains loan account information for each customer. Note:Loan Account is a type of Financial Account.
The following is an example of a ServiceNow complaint form (case form) that walks an agent through filing a complaint on behalf of a customer. In this form, the agent clicks the Account Search button on the form to locate the customer's account information.
When the agent clicks the Account Search a pop-up similar to the following appears. The pop-up allows the agent to lookup the customer's account using any of the displayed search parameters. You can create your own search criteria based on your specific web service. These web services generally come from Customer Master and Account Master systems, CRMs, core banking mainframes, and APIs from core banking software providers such as Fiserv, FIS, Jack Henry, Finastra and others.
The search returns the following accounts for this customer.
The agent selects the appropriate account and the necessary account information is automatically populated in the case form. The agent then adds any additional information needed to submit the customer case and clicks the Submit button to save the complaint in the ServiceNow instance.
The following diagram shows the flow of the REST API calls for this use case and provides brief remarks on any required processing.
|
Example code
// Fetch consumers for the given first name and last name and associated
// financial accounts from the remote bank application
function fetchConsumers(consumer_fname, consumer_lname) {
var request = new sn_ws.RESTMessageV2();
request.setHttpMethod('get');
request.setEndpoint('api/getConsumerDetails?fname=consumer_fname&lname=consumer_lname');
var response = request.execute();
var responseBody = response.getBody();
var responseObj = JSON.parse(responseBody);
var consumers = responseObj.consumers;
// Create a record in the ServiceNow Consumer [csm_consumer] table for the specified consumer
var consumerDetails = [];
consumers.foreach(function(consumer){
var consumerGR = new GlideRecord('csm_consumer');
consumerGR.initialize();
consumerGR.setValue('uid', consumer.uid);
consumerGR.setValue('name', consumer.name);
consumerGR.setValue('email', consumer.email);
consumerGR.setValue('mobile', consumer.mobile);
consumerGR.setValue('address', consumer.address);
if(consumerGR.update()){
consumer.sysId = consumerGR.getValue('sys_id');
consumer.financialAccount = fetchFinancialAccountsForConsumer(consumer);
}
});
}
// Fetch financial accounts for the specified consumer
function fetchFinancialAccountsForConsumer(consumer) {
var financialAccounts = [];
var request = new sn_ws.RESTMessageV2();
request.setHttpMethod('get');
request.setEndpoint('api/getFinancialAccounts/' + consumer);
var response = request.execute();
var responseBody = response.getBody();
var responseObj = JSON.parse(responseBody);
var financialAccounts = responseObj.financialAccounts;
// Create a record in the ServiceNow financial_account table for each of the customer's financial accounts
financialAccounts.foreach(function(finAccount){
var finAccountGR = new GlideRecord('financial_account');
finAccountGR.initialize();
finAccountGR.setValue('uid', finAccount.uid);
finAccountGR.setValue('type', finAccount.type);
finAccountGR.setValue('number', finAccount.ac_number);
finAccountGR.setValue('balance', finAccount.balance);
if(finAccountGR.update()){
finAccount.sysId = finAccountGR.getValue('balance');
financialAccounts.push(finAccount);
}
});
return financialAccounts;
}
// The following retrieves an object to display in UI page
fnmae = ‘john’;
lname = ‘brown’;
var consumerObj = fetchConsumers(fname, lname);
consumerObj.foreach(function(consumer){
// Display the details on the page and populate it in the form as necessary
console.log(consumer);
});