executeReport

This function runs an existing report, using its report_id. This is obtained from the get_reports function.

Input

Class Name Type Required Details
ExecuteReportRequest userId String Yes The caller’s user name
ExecuteReportRequest password String Yes The caller’s password
ExecuteReportRequest status String No The status of the items being collected
ExecuteReportRequest pageLength Integer Yes The page length
ExecuteReportRequest persistHandle String No A random string to persist the data
ExecuteReportRequest recordStart Integer No The starting index of records returned
ExecuteReportRequest recordCount Integer No The count of records being fetched
ExecuteReportRequest returnRawXML boolean No Determines whether raw XML will be returned with the parse fields. This should be set to false for better performance

Output

Class Name Type Required Details
ExecuteReportResponse success boolean Yes True is succeeded False if failed
ExecuteReportResponse returnCode String No See Appendix for details
ExecuteReportResponse returnMessage String No Human readable message
ExecuteReportResponse xmlResults String No The search results in XML format
ExecuteReportResponse itemRecords Array[] Yes An array of ItemRecord objects
ItemRecord numberOfItemRecordFields int Yes The number of field records in the child array
ItemRecord itemRecordFields Array[] Yes An array of ItemRecordField objects
ItemRecordField fieldId String Yes The id of the field
ItemRecordField fieldTitle String Yes The title of the field
ItemRecordField fieldValue String Yes The value of the field
ItemRecordField row int Yes The repeating row value

Example 1

public static void testExecuteReport(EVReportServiceStub stub) {
try {
ExecuteReportDocument reqEnvelope = ExecuteReportDocument.Factory.newInstance();
ExecuteReportRequest request = reqEnvelope.addNewExecuteReport().addNewRequest();
request.setUserId(ServiceClientHelper.ADMIN_USER_ID);
request.setPassword(ServiceClientHelper.ADMIN_PASSWORD);
request.setPageLength(100);
request.setRecordStart(1);
request.setRecordCount(120);
request.setPersistHandle(ServiceClientHelper.randStr);
request.setReportId(ServiceClientHelper.STANDARD_REPORT);
ExecuteReportResponseDocument resEnvelope = stub.executeReport(reqEnvelope);
ExecuteReportResponse response = resEnvelope.getExecuteReportResponse().getReturn();
if (response.getSuccess()) {
System.out.println("success: [" + response.getReturnCode() + "] : " +
response.getReturnMessage());
} else {
System.out.println("failure: [" + response.getReturnCode() + "] : " +
response.getReturnMessage());
}
} catch (Exception e) {
e.printStackTrace();
System.err.println("nnn");
}
}

Example 2

This is sample code for specifying runtime filters for a hierarchy report:

        executeReport request = new executeReport();
/* fill with minimum data set */
request.setSearchMode("ADVANCED");
request.setApiReverseLookup("YES");
List<AdvancedFilterData> filters = new ArrayList<AdvancedFilterData>();
AdvancedFilterData filter = null;
// Priority = P 1 at base level
filter = new AdvancedFilterData();
filter.setFset("0");
filter.setFieldName("PRIORITY");
filter.setOperator("=");
filter.setValue1_EVDISPLAY("P 1");
filter.setMvalue1("");
filter.setValue2("");
filters.add(filter);
//  DATE_CREATED between 09/01/2017 and 09/30/2017 at hierarchy level 1
filter = new AdvancedFilterData();
filter.setFset("1");
filter.setFieldName("DATE_CREATED");
filter.setOperator("between");
filter.setValue1_EVDISPLAY("09/01/2017");
filter.setMvalue1("09/01/2017");
filter.setValue2("09/30/2017");
filters.add(filter);
request.setAdvancedFilterData(filters.toArray(new AdvancedFilterData[filters.size()]));

Example 3

This is sample code for specifying runtime filters a non-hierarchy report

        executeReport request = new executeReport();
/* fill with minimum data set */
request.setSearchMode("ADVANCED");
request.setApiReverseLookup("YES");
List<AdvancedFilterData> filters = new ArrayList<AdvancedFilterData>();
AdvancedFilterData filter = null;
// Priority = P 1
filter = new AdvancedFilterData();
filter.setFset("0");  // non-hierarhcy
filter.setFieldName("PRIORITY");
filter.setOperator("=");
filter.setValue1_EVDISPLAY("P 1");
filter.setMvalue1("");
filter.setValue2("");
filters.add(filter);
//  DATE_CREATED between 09/01/2017 and 09/30/2017
filter = new AdvancedFilterData();
filter.setFset("0");  // non-hierarhcy
filter.setFieldName("DATE_CREATED");
filter.setOperator("between");
filter.setValue1_EVDISPLAY("09/01/2017");
filter.setMvalue1("09/01/2017");
filter.setValue2("09/30/2017");
filters.add(filter);
request.setAdvancedFilterData(filters.toArray(new AdvancedFilterData[filters.size()]));

Example 4

This is sample code for specifying runtime filters along with standard filters within a hierarchy report

        executeReport request = new executeReport();
/* fill with minimum data set */
request.setApiReverseLookup("YES");
List<FilterData> filters = new ArrayList<FilterData>();
FilterData filter = null;
// Priority = P 1
filter = new FilterData();
filter.setName("PRIORITY");
filter.setValue("P 1");
filters.add(filter);
// Category= Software
filter = new FilterData();
filter.setName("CATEGORY");
filter.setValue("Software");
filters.add(filter);
request.setFilterData(filters.toArray(new FilterData[filters.size()]));