General API classes and methods
The TrueSight Network Automation Web Services API provides a general set of classes which abstract the lower-level web service functionality into a set of easy to use Java classes. Each service class offers several methods for retrieving and modifying objects, and executing actions on the server.
In addition to the service classes, the API provides a set of Data Transfer Object (DTO) classes. The DTO classes are lightweight containers for passing data to and from the server. For example, to retrieve a set of devices from the server, the client constructs a DeviceFilterDTO object. This object is then passed to the DeivceService.getDevices() method. The method returns a set of DeviceDTO objects. Each DTO object is documented in the Javadoc provided in the TrueSight Network Automation Web Services distribution file.
Most DTO components, such as configurations, rules, or devices, have an associated key value, that is used to retrieve DTO data whenever possible. The advantage of using a key over a name is that the key remains intact while the name can be changed on the GUI.
The following sections document the key methods in each of the service classes.
- AuthenticationService class
- ComplianceService class (deprecated in version 8.9.04)
- DeviceSecurityProfileService class (deprecated in version 8.9.04)
- DeviceService class (deprecated in version 8.9.04)
- EndpointActionService class (deprecated in version 8.9.04)
- EventService class
- ExternalScriptActionService class (deprecated in version 8.9.04)
- GroupService class (deprecated in version 8.9.04)
- ImportExportService class
- JobApprovalTypeService class (deprecated in version 8.9.04)
- JobService class (deprecated in version 8.9.04)
- PredefinedJobService class (deprecated in version 8.9.04)
- RealmService class (deprecated in version 8.9.04)
- ReportService class
- RuleService class (deprecated in version 8.9.04)
- RuleSetService class (deprecated in version 8.9.04)
- SecurityVulnerabilityService class (deprecated in version 8.9.04)
- SpanActionService class (deprecated in version 8.9.04)
- SpanService class
- SubstitutionParameterService class (deprecated in version 8.9.04)
- TemplateGroupService class (deprecated in version 8.9.04)
- UserService class (deprecated in version 8.9.04)
 
AuthenticationService class
The AuthenticationService class provides authentication services such as login and logout. This service must be used by every application for authenticating a user and establishing a user session for accessing the TrueSight Network Automation system.
Retrieve the WSDL for this service by using the https://<<server:port>>/bca-networks/services/AuthenticationService?wsdl URL.
| Method | Description | 
|---|---|
| doLogin() | Logs on a user to the system and starts a web service session. A unique token is returned that must be used for all subsequent calls to identify the session. Authentication and authorization on each subsequent call is based on this unique token. | 
| doLogout() | Logs out a user from the system and ends the web service session. | 
| getSessionTimeout() | Returns the web service session timeout value, in minutes. This is the amount of time after which the server forcefully logs out a user out due to a period of inactivity. This is also the time configured in the wsSessionTimeOutMinutes property, which is present in the BCAN_DATA/global.properties file on the server. | 
| getUsers() | Returns the names of all users in the system. | 
| isLoggedIn() | Returns a true value if a valid user session is in progress. | 
ComplianceService class (deprecated in version 8.9.04)
The ComplianceService class provides calls related to TrueSight Network Automation compliance.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/ComplianceService?wsdl URL.
| Method | Description | 
|---|---|
| createCompliancePredefinedJob() | Creates a TrueSight Network Automation predefined job with the given span and compliance rule sets. The predefined job is created with one Compliance Status action. Once the predefined job is created, a job is prepared from it and submitted for execution at the specified run time. | 
| executeComplianceJob() | Prepares and schedules a job for execution by preparing one from the specified predefined job. | 
| getComplianceDetailResults() | Returns the detailed results of the Compliance Status job. | 
| getComplianceSummaryResults() | Returns the summary level results of the Compliance Status job that most recently originated from the predefined job. | 
DeviceSecurityProfileService class (deprecated in version 8.9.04)
The DeviceSecurityProfileService class provides services to enumerate, add, modify, or delete device security profiles.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/DeviceSecurityProfileService?wsdl URL.
| Method | Description | 
|---|---|
| addDeviceSecurityProfile() | Adds a new device security profile to the system. | 
| deleteDeviceSecurityProfile() | Deletes a device security profile. | 
| getDeviceSecurityProfileByName() | Returns the device security profile by name. Values of the all password fields of the returned device security profile are dummy and are different from the real values that are hidden. | 
| getDeviceSecurityProfiles() | Returns all the device security profiles from the server. Values of the all password fields of the returned device security profile are dummy and are different from the real values that are hidden. | 
| modifyDeviceSecurityProfile() | Modifies a device security profile. | 
DeviceService class (deprecated in version 8.9.04)
The DeviceService class provides a variety of services related to devices, including retrieval of device objects and device configurations.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/DeviceService?wsdl URL.
| Method | Description | 
|---|---|
| addDevice() | Adds a new device to the system. | 
| deleteDevice() | Deletes an existing device from the system. | 
| deleteDeviceExtended() | (Version 8.5.01 and later) Deletes a device like the deleteDevice() method, but with the following differences: 
 
 | 
| getDevice() | Returns a single device based on the provided device key. This method is typically used when the device key is available from a previous call. For example, the device key may be stored in a data file from a previous run so this method is used to retrieve the device DTO object based on the stored device key. | 
| getDeviceCount() | Returns an integer count of the number of devices in the TrueSight Network Automation database. You can get the count of on-line devices only or all devices (both on-line and off-line) by passing in the appropriate value for the boolean flag, onlineOnly. | 
| getDevices() | Returns a set of devices that match the provided device filter. | 
| getConfiguration() | Returns a single device configuration based on the provided configuration key. The configuration key can be determined from the device DTO objects returned from the getDevices() or getDevice() methods. | 
| getServiceContextInfo() | Returns Service Context information for the business service name, further filtered by the device filter that is passed as input. The changes to the device configuration over the time period provided as input are captured in an array of change DTO ordered by latest configuration created date first. You can specify a number of changes to retrieve to limit changes returned by the call. | 
| modifyDevice() | Modifies an existing device in the system. | 
EndpointActionService class (deprecated in version 8.9.04)
The EndpointActionService class provides services to run endpoint actions.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/EndpointActionService?wsdl URL.
| Method | Description | 
|---|---|
| doFindEndpoint() | Finds the managing switch for a specified endpoint address. Note: If you do not specify the spanKeys argument, this action searches the entire network for the endpoint. | 
| doQuarantineEndpointViaBlockEndpoint() | Finds the managing switch for the specified endpoint and modifies it to block all IP traffic involving the endpoint. | 
| doQuarantineEndpointViaDisablePort() | Finds the managing switch for the specified endpoint and modifies it to shutdown the port on which the endpoint was last seen. | 
| doQuarantineEndpointViaRemediateEndpoint() | Finds the managing switch for the specified endpoint and modifies it to block all IP traffic involving the endpoint except for the specified remediation address. | 
| doQuarantineEndpointViaRemediateEndpointByVLAN() | Finds the managing switch for the specified endpoint and changes the VLAN membership of the switch port associated with the endpoint to the specified remediationVlan. After the quarantine the endpoint is accessible only from the remediation VLAN network. | 
| doUnquarantineEndpoint() | Unquarantines the specified endpoint address within the managing switch associated with the endpoint. | 
| getEndpointActionResults() | Returns the endpoint action results for the job with given jobID. | 
EventService class
The EventService class provides services to log events of various severity levels on the server.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/EventService?wsdl URL.
| Method | Description | 
|---|---|
| doLogCriticalEvent() | Logs a CRITICAL severity event on the server. | 
| doLogInfoEvent() | Logs an INFO severity event on the server. | 
| doLogMajorEvent() | Logs a MAJOR severity event on the server. | 
| doLogMinorEvent() | Logs a MINOR severity event on the server. | 
| doLogWarningEvent() | Logs a WARNING severity event on the server. | 
ExternalScriptActionService class (deprecated in version 8.9.04)
The ExternalScriptActionService class provides services to execute and monitor a job containing external script actions.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/ExternalScriptActionService?wsdl URL.
| Method | Description | 
|---|---|
| doExternalScriptAction() | Executes the given external script action. | 
| getExternalScriptActionResults() | Returns the results of a job that has executed external script actions. | 
GroupService class (deprecated in version 8.9.04)
The GroupService class provides services to retrieve groups.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/GroupService?wsdl URL.
| Method | Description | 
|---|---|
| addSimpleGroup() | Adds a new simple group to the system. | 
| deleteSimpleGroup() | Deletes a simple group. | 
| getCombogroup() | Returns the combo group details by the key provided. | 
| getCombogroups() | Returns a set of combo groups that match the provided group filter. | 
| getSimpleGroup() | Returns the simple group details by the key provided. | 
| getSimpleGroups() | Returns a set of simple groups (for example, Auto-Groups and Static Groups) that match the provided group filter. | 
| modifySimpleGroup() | Modifies a simple group, optionally including its member devices. | 
ImportExportService class
The ImportExportService class contains methods that apply to components that use general and Virtual Data Center (VDC) API classes. This class acts an interface, which provides an API to perform the following tasks:
- Import components in XML format to the TrueSight Network Automation database.
- Export components from the TrueSight Network Automation database to XML.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/ImportExportService?wsdl URL.
| Method | Description | 
|---|---|
| (Version 8.9.01 and later) | Exports all combo groups from database to XML data. | 
| (Version 8.9.01 and later) | Exports all conditions from database to XML data. | 
| exportContainerBlueprints() | Exports all container blueprints from database to XML data. | 
| exportContainers() | Exports all containers from database to XML data. | 
| exportDeviceSecurityProfiles() | Exports device security profiles (DSP) from database to XML. | 
| (Version 8.9.01 and later) | Exports dynamic fields from database to XML. | 
| (Version 8.9.01 and later) | Exports all keywords from database to XML data. | 
| exportPodBlueprints() | Exports all pod blueprints from database to XML data. | 
| exportPods() | Exports all pods from database to XML data. | 
| (Version 8.9.01 and later) | Exports all policies from database to XML data. | 
| exportPredefinedJobs() | Exports predefined jobs from database to XML data. | 
| exportRemoteFileServers() | Exports remote file servers from database to XML data. | 
| (Version 8.9.01 and later) | Exports roles from database to XML data. | 
| exportRules() | Exports rules from database to XML data. | 
| exportRuleSets() | Exports rule sets from database to XML data. | 
| exportSubstitutionParameters() | Exports global substitution parameters from database to XML data. | 
| exportTemplateGroups() | Exports template groups from database to XML data. | 
| importComponents() | Imports any of the components that can be exported using the methods listed above into the TrueSight Network Automation database.  | 
JobApprovalTypeService class (deprecated in version 8.9.04)
The JobApprovalTypeService class provides services to retrieve job approval types.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/JobApprovalTypeService?wsdl URL.
| Method | Description | 
|---|---|
| getJobApprovalTypeByName() | Returns the job approval type that matches the given job approval type name. | 
| getJobApprovalTypes() | Returns all the job approval types in the system. | 
JobService class (deprecated in version 8.9.04)
The JobService class provides services to approve or reject jobs and retrieve job status. Some methods in this class are relocated from the SpanActionService class.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/JobService?wsdl URL.
| Method | Description | 
|---|---|
| doApprovalByChangeID() | Approves or rejects all TrueSight Network Automation jobs with the given change ID. | 
| doApprovalByJobID() | Approves or rejects an TrueSight Network Automation job with the given job ID. | 
| doApprovalByTaskID() | Approves or rejects all TrueSight Network Automation jobs with the given task ID. | 
| doExternalApproval() | Approves or rejects a TrueSight Network Automation job with the given job ID, change ID, and task ID. | 
| getActionResultSummaries() | Returns all of the device results for a particular job, in an abbreviated form that does not include device interaction transcripts. Results include action and sub-action numbers, which facilitate calls to retrieve the full device result (including the transcript) through getDeviceResult() or getDeviceResultWithSubaction(). | 
| getDeviceResult() | Returns the complete span action execution details (including the transcript) for one device in one action in a job. | 
| (Version 8.9.00 and later) | Returns the complete span action execution details (including the transcript) for one device in one sub-action in a remediating action in a job. | 
| retrieveJobStatusByChangeID() | Retrieves the current status of all jobs with the given change ID. | 
| retrieveJobStatusByJobID() | Retrieves the current status of the job with given job ID. | 
| retrieveJobStatusByTaskID() | Retrieves the current status of all jobs with given task ID. | 
| (Version 8.9.00 and later) | Retrieves parameter information for a job that performs a remediate action on selected rule sets or rules. | 
| (Version 8.9.00 and later) retrieveRemediateByEnforceablesResults() | Retrieves detailed execution status of a completed job that performed a remediate action on selected rule sets or rules. | 
PredefinedJobService class (deprecated in version 8.9.04)
The PredefinedJobService class provides services to retrieve and run predefined jobs.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/PredefinedJobService?wsdl URL.
| Method | Description | 
|---|---|
| getAllPredefinedJobNames() | Returns a list of the names of all predefined jobs. | 
| getAllSharedRuntimeParameters() | Returns a list of all shared runtime parameters for a given predefined job. | 
| getPredefinedJobNames() | Returns a list of the names of all predefined jobs that match a provided name filter (uses wildcards). | 
| getPredefinedJobParamTypes() | Returns all the parameter types for a given predefined job. | 
| getPredefinedJobs() | Returns PredefinedJobParamTypesDTO with details of the predefined job retrieved based on filter match and access rights of the logged in user. | 
| submitJob() | Prepares and submits the given predefined job using the provided set of parameters. | 
| validatePredefinedJobParams() | Validates the parameter values for a given predefined job. This method can be called before submitJob() to verify that the runtime and other parameter values are correct. | 
RealmService class (deprecated in version 8.9.04)
The RealmService class provides services to add, modify, delete, and enumerate realms.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/RealmService?wsdl URL.
| Method | Description | 
|---|---|
| addRealm() | Adds a realm. | 
| deleteRealm() | Deletes a realm. | 
| getRealmByKey() | Returns the realm details by the key provided. | 
| getRealmByName() | Returns information about a realm by the name provided. | 
| getRealms() | Returns a list of realms that are registered with the server. | 
| modifyRealm() | Modifies the properties of a realm. | 
ReportService class
The ReportService class provides services to generate, email, and retrieve report data.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/ReportService?wsdl URL.
| Method | Description | 
|---|---|
| doSendJobSummaryReportEmail() | Emails the Job Summary report to a set of e-mail addresses based on the specified report parameters. | 
| getSystemDiagnosticsReport() | (Version 8.5.01 and later) Retrieves a system diagnostics report containing all the available information for the server and every remote device agent. | 
RuleService class (deprecated in version 8.9.04)
The RuleService class provides services to retrieve and import rules.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/RuleService?wsdl URL.
| Method | Description | 
|---|---|
| (Version 8.9.00 and later) getAbbreviatedCorrectableRules() | Returns brief information about the correctable rules that match the provided filter. | 
| getRule() | Returns a single rule based on the provided rule key. This method is typically used when the rule key is available from a previous call. For example, the rule key may be stored in a data file from a previous run so this method is used to retrieve the rule DTO object based on the stored rule key. | 
| getRules() | Returns a set of rules that match the provided filter. | 
| importRules() | Imports a set of rules to the server based on the specified parameters. The import process works in the same manner as running a Rule Import from the GUI. | 
RuleSetService class (deprecated in version 8.9.04)
The RuleSetService class provides services to retrieve rule sets.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/RuleSetService?wsdl URL.
| Method | Description | 
|---|---|
| addRuleSet() | Adds a new rule set to the system. | 
| deleteRuleSet() | Deletes an existing new rule set from the system. | 
| getRuleSet() | Returns a single rule set based on the provided rule set key. This method is often used to get a rule set DTO object for a retrieved rule. The rule DTO object contains a reference to the rule set key. | 
| getRuleSets() | Returns a set of rule sets that match the provided filter. | 
| modifyRuleSet() | Modifies an existing rule set in the TrueSight Network Automation database. | 
SecurityVulnerabilityService class (deprecated in version 8.9.04)
The SecurityVulnerabilityService class provides services to import security vulnerabilities.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/SecurityVulnerabilityService?wsdl URL.
| Method | Description | 
|---|---|
| importSecurityVulnerability() | Imports a new security vulnerability into the system. | 
| importSecurityVulnerabilitiesFromZip() | Imports multiple security vulnerabilities present inside a zipped file into the system. | 
SpanActionService class (deprecated in version 8.9.04)
The SpanActionService class provides services to run Snapshot, Commit, Custom, Make Trusted, Deploy to Active, Refresh, and Deploy to Stored span actions and also to retrieve span action results of previously run actions.
Each of the span action execution calls have a parameter called waitForCompletion to indicate whether the call should block until the span action execution has completed. When the value of this parameter is false, the call returns to the client after the server creates the span action/job with the given parameters and schedules the job. For more information about this parameter, see the Javadoc provided in the TrueSight Network Automation Web Services distribution file.
When you plan to set a Run At Time value (that is, a scheduled run date/time in the future), you must set the waitForCompletion parameter to false because otherwise jobs will be held up waiting for completion of the run. For example:
If you set the waitForCompletion parameter to true, the job will fail validation and will not run; the system will report this error to the client.
For a Run At Time value, you must create the Date object using a pattern in SimpleDateFormat. For example:
/*
Example:
Pattern --- "yyyy.MM.dd G 'at' HH:mm:ss z"
Value ----- "2011.07.04 AD at 12:08:56 PDT"
*/
SimpleDateFormat sdf = new SimpleDateFormat("yyyy.MM.dd G 'at' HH:mmz");
Date date = sdf.parse("2012.06.30 AD at 12:08 PDT");
runAtCal.setTime(date);
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/SpanActionService?wsdl URL.
| Method | Description | 
|---|---|
| doBackup() | Executes a Snapshot action on one or more devices based on the specified parameters. | 
| doCommit() | Executes a Commit action on one or more devices based on the specified parameters. | 
| doCustomAction() | Executes a custom action on one or more devices based on the specified parameters. Custom actions may capture and return additional result data, which is available after calling getSpanActionResults(). | 
| doDeployOsImageByImageActiveOnDate() | Executes a Deploy OS Image job with the given OS Image source that is active on the specific date and returns the new job's jobID on one or more devices based on the specified parameters. | 
| doDeployOsImageFromFile() | Executes a Deploy OS Image job with the given OS Image source from the file and returns the new job's jobID on one or more devices based on the specified parameters. Note: Client programs must have Message Transmission Optimization Mechanism (MTOM) implementation to execute this service. | 
| doDeployOsImageFromOsImageLibrary() | Executes a Deploy OS Image job with the given OS Image source from the OS Image library and returns the new job's jobID on one or more devices based on the specified parameters. | 
| doDeployOsImageFromRemoteFileServer() | Executes a Deploy OS Image job with the given OS Image source from the remote file server and returns the new job's jobID on one or more devices based on the specified parameters. | 
| getLoadableOsImages() | Returns the details including the image key of the loadable OS images stored in the OS Image library. This image key is used when performing the doDeployOsImageFromOsImageLibrary action. | 
| Note: The doDeployOsImage*() methods might take a long time to complete depending on the size and number of image files, network connectivity to the device, and the device processing time. | |
| doMarkAsTrustedByConfigDate() doMarkAsTrustedByConfigKey() | Executes a Mark as Trusted action on one or more devices based on the specified parameters. | 
| doMergeByAdhocTemplate() doMergeByConfigKey() doMergeByConfigType() doMergeByTemplateGroup() (Deprecated in version 8.9.00) doMergeCompliantAllAssigned() (Deprecated in version 8.9.00) doMergeCompliantByRule() (Deprecated in version 8.9.00) doMergeCompliantByRuleSet() | Executes a Deploy to Active action on one or more devices based on the specified parameters. | 
| doMergeByAdhocTemplateExtended() doMergeByConfigKeyExtended() doMergeByConfigTypeExtended() doMergeByTemplateGroupExtended() | Executes a Deploy to Active action on one or more devices based on the specified parameters. These methods are similar to the preceding set of methods, but with additional options: 
 | 
| doMergeByAdhocInjectionTemplateExtended() | Executes a Deploy to Active action on one or more devices based on the specified parameters. This method is the same as the preceding set of methods but with the following additional option, injectionTemplate. | 
| (Deprecated in version 8.9.00) doMergeCompliantAllAssignedExtended() (Version 8.9.00 and later) doMergeCompliantAllAssignedExtended2() (Deprecated in version 8.9.00)  (Version 8.9.00 and later) doMergeCompliantByRuleExtended2() (Deprecated in version 8.9.00) doMergeCompliantByRuleSetExtended() (Version 8.9.00 and later) doMergeCompliantByRuleSetExtended2() | Executes a Deploy to Active action on one or more devices based on the specified parameters. These methods are similar to the preceding set of methods but with additional options: 
 | 
| doRefreshStatus | Executes a Deploy to Active action on one or more devices based on the provided parameters. | 
| (Version 8.9.00 and later) | Executes a Remediate action on one or more devices to correct all the rules currently in violation. | 
| (Version 8.9.00 and later) doRemediateByEnforceables() | Executes a Remediate action on one or more devices to correct specified rule sets and rules. | 
| doRestoreByTemplateGroup | Executes a Deploy to Stored action on one or more devices based on the provided parameters. | 
| getSpanActionResults | Returns the span action results of a job that has executed with the given job ID. | 
SpanService class
The SpanService class offers a service related to span.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/SpanService?wsdl URL.
| Method | Description | 
|---|---|
| getSpans() | Returns the details of spans. | 
SubstitutionParameterService class (deprecated in version 8.9.04)
The SubstitutionParameterService class provides services to manage substitution parameters.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/SubstitutionParameterService?wsdl URL.
| Method | Description | 
|---|---|
| addSubstitutionParameter() | Adds a new substitution parameter to the system. | 
| deleteSubstitutionParameter() | Deletes a substitution parameter from the system. | 
| getSubstitutionParameterByName() | Returns the details of a substitution parameter based on the given name. | 
| getSubstitutionParameters() | Returns all substitution parameters from the system. | 
| modifySubstitutionParameter() | Modifies an existing substitution parameter in the system. | 
TemplateGroupService class (deprecated in version 8.9.04)
The TemplateGroupService class provides services to manage template groups.
Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/TemplateGroupService?wsdl URL.
| Method | Description | 
|---|---|
| addTemplateGroup() | Adds a new template group to the system. | 
| deleteTemplateGroup() | Deletes a template group from the system. | 
| getTemplateGroupByName() | Returns the details of a template group based on the given name. | 
| getTemplateGroups() | Returns all template groups from the system. | 
| modifyTemplateGroup() | Modifies an existing template group in the system. | 
UserService class (deprecated in version 8.9.04)
The UserService class provides services to add, modify, delete, retrieve all users, and retrieve a particular user by using the user name or user key. 
 
 Retrieve the WSDL for this service by using the https://<server:port>/bca-networks/services/UserService?wsdl URL.
| Method | Description | 
|---|---|
| addUser() | Adds a new user to the system. | 
| deleteUser() | Deletes an existing user from the system. | 
| getUsers() | Returns users from the database. | 
| getUserByName() | Returns a user by matching the given name. | 
| getUserByKey() | Returns a single user based on the provided user key. | 
| modifyUser() | Modifies the properties of existing user in the system. | 
