Asset Management and Tagging API v2. User Guide Version 2.9



Similar documents
Asset Management and Tagging API v1. User Guide Version 2.3

Offline Scanner Appliance

Qualys API V1. User Guide. Version 8.6

Qualys PC/SCAP Auditor

Security and Compliance Suite Rollout Guide. August 4, 2015

QualysGuard WAS. Getting Started Guide Version 4.1. April 24, 2015

NE T GENERATION CLOUD SECURITY PLATFORM

Web Application Firewall

Policy Compliance. Getting Started Guide. January 22, 2016

QualysGuard WAS. Getting Started Guide Version 3.3. March 21, 2014

QualysGuard Asset Management

Bringing Continuous Security to the Global Enterprise

Scanner Appliance. User Guide. April 6, 2015

Qualys API Release Notes

Qualys API. Network Support Qualys Version 8.2

2015 GAAP. Cash Flow. compliance. our customer. revolutionary. for the fourth. to existing. customers. Media Contact: Don McCauley

SSL Server Rating Guide

Wind River. Intelligent Device Platform XT EMS Profile EMS DEVICE MANAGEMENT USER'S GUIDE WIND RIVER 1.0

Secret Server Qualys Integration Guide

Message Containers and API Framework

An Oracle White Paper June RESTful Web Services for the Oracle Database Cloud - Multitenant Edition

Compute RESTful API. Programmer s Guide. Revision 1.4 (11/10/2013) COMPUTE RESTFUL API

NARROWING THE SECURITY GAP WITH AUTOMATED CONFIGURATION ASSESSMENT

Apache CloudStack 4.x (incubating) Network Setup: excerpt from Installation Guide. Revised February 28, :32 pm Pacific

Microsoft Active Directory Oracle Enterprise Gateway Integration Guide

FireEye App for Splunk Enterprise

NMS300 Network Management System

Enhanced Connector Applications SupportPac VP01 for IBM WebSphere Business Events 3.0.0

OpenLDAP Oracle Enterprise Gateway Integration Guide

Tutorial: Using HortonWorks Sandbox 2.3 on Amazon Web Services

How To Tag Assets In A Microsoft Qoq On A Microsq.Com (For Free) On A Pc Or Macbook Or Macsoft.Com On A Macbook (For Paid) On An Ipad Or Ipad (

Managing Qualys Scanners

Riverbed Cascade Shark Common REST API v1.0

Oracle Forms Services Secure Web.Show_Document() calls to Oracle Reports Server 6i

Use Enterprise SSO as the Credential Server for Protected Sites

Qualys API Limits. July 10, Overview. API Control Settings. Implementation

IP Filtering for Patton RAS Products

Host Discovery with nmap

Help us make this document better smarttech.com/docfeedback/ Security information

Sonian Getting Started Guide October 2008

API V2.0. Documentation 7/28/2014

Contents. 2 Alfresco API Version 1.0

Internet Technologies. World Wide Web (WWW) Proxy Server Network Address Translator (NAT)

Qlik REST Connector Installation and User Guide

Vulnerability Scan Results in XML

fåíéêåéí=péêîéê=^çãáåáëíê~íçêûë=dìáçé

Copyright 2013, 3CX Ltd.

vcloud Air Platform Programmer's Guide

GETTING STARTED WITH THE PCI COMPLIANCE SERVICE VERSION 2.3. May 1, 2008

TRIPWIRE PURECLOUD. TRIPWIRE PureCloud USER GUIDE

CounterACT Plugin Configuration Guide for ForeScout Mobile Integration Module MaaS360 Version ForeScout Mobile

Creating an ESS instance on the Amazon Cloud

Setting Up Scan to SMB on TaskALFA series MFP s.

IP Phone Service Administration and Subscription

Application Discovery Manager User s Guide vcenter Application Discovery Manager 6.2.1

About the VM-Series Firewall

HOST EUROPE CLOUD STORAGE REST API DEVELOPER REFERENCE

BMC Track-It! Web. Web Services API Guide. Version 11.3

Configuration Information

Configuring BEA WebLogic Server for Web Authentication with SAS 9.2 Web Applications

IBM Endpoint Manager Version 9.1. Patch Management for Red Hat Enterprise Linux User's Guide

Quick Start Guide. 1 Copyright 2014 Samanage

Easy CramBible Lab DEMO ONLY VERSION Test284,IBM WbS.DataPower SOA Appliances, Firmware V3.6.0

API documentation - 1 -

Using QUalysgUard to Meet sox CoMplianCe & it Control objectives

NETWRIX EVENT LOG MANAGER

TRUSTWAVE VULNERABILITY MANAGEMENT USER GUIDE

Log Forwarder for Windows SolarWinds, Inc.

Nessus Enterprise Cloud User Guide. October 2, 2014 (Revision 9)

Data Mailbox. support.ewon.biz. Reference Guide

IBM Security QRadar SIEM Version MR1. Vulnerability Assessment Configuration Guide

Accessing Your Database with JMP 10 JMP Discovery Conference 2012 Brian Corcoran SAS Institute

Lab Exercise SSL/TLS. Objective. Step 1: Open a Trace. Step 2: Inspect the Trace

Kofax Export Connector for Microsoft SharePoint

Elastic Detector on Amazon Web Services (AWS) User Guide v5

Axway API Gateway. Version 7.4.1

UFTP AUTHENTICATION SERVICE

IronBee Open Source Web Application Firewall

ALTIRIS CMDB Solution 6.5 Product Guide

Automating Server Firewalls

Active Directory Extension User Guide. Version 1.0

User-ID Features. PAN-OS New Features Guide Version 6.0. Copyright Palo Alto Networks

LifeSize UVC Access Deployment Guide

An Oracle White Paper June Security and the Oracle Database Cloud Service

5nine Cloud Security Azure Pack Extension. Version 5.2

PCI Compliance. Network Scanning. Getting Started Guide

KB Microsoft Network Security Hotfix Checker (Hfnetchk.exe) Tool Is Available

Deploying Virtual Cyberoam Appliance in the Amazon Cloud Version 10

FileMaker Server 10 Help

McAfee Web Gateway Administration Intel Security Education Services Administration Course Training

Dell One Identity Quick Connect for Cloud Services 3.6.1

CloudStack Metering Working with the Usage Data. Tariq Iqbal Senior

Information on Syslog For more information on syslog, see RFC Released: December 2006 Interoperability issues: None. Table 1: Syslog at a Glance

White Paper. Deploying EUM. SurfControl Web Filter for MS Windows. rev. 1.1, January Enterprise Threat Protection

WatchDox Administrator's Guide. Application Version 3.7.5

McAfee Vulnerability Manager 7.0.2

Google Apps Deployment Guide

Security and Compliance Suite

DNS Update API November 15, 2006 Version 2.0.3

Bitcoin Payment Gateway API

Transcription:

Asset Management and Tagging API v2 User Guide Version 2.9 July 15, 2015

Copyright 2013-2015 by Qualys, Inc. All Rights Reserved. Qualys, the Qualys logo and QualysGuard are registered trademarks of Qualys, Inc. All other trademarks are the property of their respective owners. Qualys, Inc. 1600 Bridge Parkway Redwood Shores, CA 94065 1 (650) 801 6100

Preface Chapter 1 Welcome Get Started... 7 Get API Notifications... 7 Introduction to the API Framework... 8 Request URL... 8 Base URL to the Qualys API Server... 8 Authentication... 9 Usage... 10 Object types... 10 Collections... 10 Whitespace in XML tags... 11 Pagination... 11 Limit your results... 12 Chapter 2 Tag API Get Tag Info... 14 Create Tag... 16 Get to know Groovy... 18 Update Tag... 19 Search Tags... 23 Count Tags... 26 Delete Tag... 27 Evaluate Tag... 28 Tag Fields... 30 Chapter 3 Host Asset API Get Host Asset Info... 32 Create Host Asset... 34 Update Host Asset... 37 Search Hosts Assets... 42 Count Host Assets... 45 Delete Host Asset... 46 Activate Host Asset... 48 Host Asset Fields... 50 Chapter 4 Asset API Get Asset Info... 54 Update Asset... 56 Search Assets... 60

Contents Count Assets... 62 Delete Asset... 63 Activate Asset... 65 Asset Fields... 68 Chapter 5 Host Instance Vulnerability API Get Vulnerability Info... 70 Search Vulnerabilities... 72 Count Vulnerabilities... 74 Host Instance Vulnerability Fields... 75 Chapter 6 Asset Data Connector API Get Connector Info... 78 Update Connector... 80 Search Connectors... 84 Count Connectors... 87 Delete Connector... 88 Run Connector... 90 Connector Fields... 93 Chapter 7 AWS Asset Data Connector API Get AWS Connector Info... 96 Create AWS Connector... 98 Update AWS Connector... 101 Search AWS Connectors... 103 Count AWS Connectors... 106 Delete AWS Connector... 107 Run Connector... 109 AWS Connector Fields... 110 Chapter 8 AWS Authentication Record API Get AWS Auth Record Info... 114 Create AWS Auth Record... 115 Update AWS Auth Record... 117 Search AWS Auth Records... 119 Count AWS Auth Records... 121 Delete AWS Auth Record... 122 AWS Auth Record Fields... 124 4 Qualys Asset Management and Tagging API

Preface Using the Qualys Asset Management and Tagging API, third parties can integrate the Qualys Security and Compliance solution into their own applications using an extensible XML interface. This user guide is intended for application developers who will use the Qualys Asset Management and Tagging API. About Qualys Qualys, Inc. (NASDAQ: QLYS) is a pioneer and leading provider of cloud security and compliance solutions with over 7,700 customers in more than 100 countries, including a majority of each of the Forbes Global 100 and Fortune 100.The Qualys Cloud Platform and integrated suite of solutions help organizations simplify security operations and lower the cost of compliance by delivering critical security intelligence on demand and automating the full spectrum of auditing, compliance and protection for IT systems and web applications. Founded in 1999, Qualys has established strategic partnerships with leading managed service providers and consulting organizations including Accenture, Accuvant, BT, Cognizant Technology Solutions, Dell SecureWorks, Fujitsu, HCL Comnet, InfoSys, NTT, Tata Communications, Verizon and Wipro. The company is also a founding member of the Cloud Security Alliance (CSA) and Council on CyberSecurity. The company is also a founding member of the Cloud Security Alliance (CSA). For more information, please visit www.qualys.com. Contact Qualys Support Qualys is committed to providing you with the most thorough support. Through online documentation, telephone help, and direct email support, Qualys ensures that your questions will be answered in the fastest time possible. We support you 7 days a week, 24 hours a day. Access support information at www.qualys.com/support/.

Preface 6 Qualys Asset Management and Tagging API

1 Welcome Welcome to Qualys Asset Management and Tagging API. The sections that follow describe how to use the Tags API, Host Asset API, Asset API and the Host Instance Vulnerability API. Get Started Introduction to the API Framework - We recommend you review important information about the API framework. Base URL to the Qualys API Server - We ll give you the basics about making API requests. The base URL depends on the platform where your Qualys account is located. Authentication - We ll tell you about the method used for authentication. API requests must authenticate using Qualys credentials. Usage - Check out the basics about making requests and receiving data from our asset management application. Get API Notifications We recommend you join our Community and subscribe to our API notifications so you ll get email notifications telling you about important upcoming API enhancements and changes. From our Community Join our Community Subscribe to API Notifications (select Receive email notifications)

Chapter 1 Welcome Introduction to the API Framework Introduction to the API Framework The Qualys Asset Management and Tagging API framework offers numerous innovations and new functionality compared to the other Qualys API frameworks. Request URL The URL for making Asset Management and Tagging API requests respects the following structure: https://<baseurl>/qps/rest/2.0/<operation>/<module>/<object>/<object_id> where the components are described below. <baseurl> <operation> <module> <object> <object_id> The Qualys API server URL that you should use for API requests depends on the platform where your account is located. The base URL for Qualys US Platform 1 is: https://qualysapi.qualys.com The request operation, such as get a list, get a count, search, create, and update. The API module. For the Asset Management and Tagging API, the module is: am. The module specific object. (Optional) The module specific object ID, if appropriate. Base URL to the Qualys API Server The Qualys API documentation and sample code within it use the API server URL for the Qualys US Platform 1: qualysapi.qualys.com. The Qualys API server URL that you should use for API requests depends on the platform where your account is located. Account Location Qualys US Platform 1 Qualys US Platform 2 Qualys EU Platform API Server URL https://qualysapi.qualys.com https://qualysapi.qg2.apps.qualys.com https://qualysapi.qualys.eu 8 Qualys Asset Management and Tagging API

Chapter 1 Welcome Introduction to the API Framework Authentication The application must authenticate using Qualys account credentials (user name and password) as part of the HTTP request. The credentials are transmitted using the Basic Authentication Scheme over HTTPS. For more information, see the Basic Authentication Scheme section of RFC #2617: http://www.faqs.org/rfcs/rfc2617.html The exact method of implementing authentication will vary according to which programming language is used. The allowed methods, POST and/or GET, for each API request are documented with each API call in this user guide. Example Basic authentication - recommended option: curl -u "USERNAME:PASSWORD" https://qualysapi.qualys.com/qps/rest/2.0/count/am/hostasset where portal.qualys.com is the base URL to the Qualys API server where your account is located. Qualys Asset Management and Tagging API 9

Chapter 1 Welcome Usage Usage Object types You have core objects, which represent domain objects for specific business goals and related objects which contain related information or collections of information. Related objects are often simplified representations of core objects but are not implicitly core objects. For example, the tags collection on Asset is a simpler form of the Tag core object, but the ports collection is not. Collections Collections of related objects are found within a container object called a QList. These lists will have a specific name for the type of objects they contain. For example, the tags collection Asset is a TagSimpleQList and will read and write TagSimple API objects. These lists can contain a number of sub elements. Element count list set add remove update Purpose (Read only) The total number of items returned in the list element (Read only) The items contained in the collection on the server A new collection of items to place in the server side object. Any existing items not in the list provided will be discarded. A new item to be added to the server side object. The item may be keyed of one ore more fields depending on the collection. In the even that that an item in the add collection collides with an existing entry, the existing entry will be updated with the fields provided. Many collections will allow you to either associate an existing item with the targeted collection, or create a new one and add it to the collection. If you provide a key field, most often id or uuid, the object will be looked up and associated. In the absence of these fields, a new object will be created (if the list allows it). Removes an element from the list by the collections key, usually id. If the item does not exist, the entry will be ignored. Additional fields beyond the item key will also be ignored. Updates item(s) in the collection. This allows you to update the fields of non-core items via the objects and reference them. Items will be resolved by the collection s key, and then additional fields applied to the found object. In the event that the supplied item does not match an existing related object, it will be ignored. 10 Qualys Asset Management and Tagging API

Chapter 1 Welcome Usage Whitespace in XML tags Whitespace (which includes line breaks) is not allowed in XML tags that are numbers. Invalid tag This syntax will not work: <id> 34234 </id> Valid tag This syntax will work just fine: <id>345254</id> Pagination Some API actions will return a list of core objects but will limit the number returned (default is 100). You can change which objects are returned and the number of objects by specifying a preferences tag in the POST body of your request. Preferences tag fields Name Description startfromoffset The first item to return by index. The default is 0. startfromid The first item to return by primary key. No default value. limitresults The total number of items to return. The default is 100. Example <?xml version="1.0" encoding="utf-8"?> <ServiceRequest> <preferences> <startfromoffset>100</startfromoffset> <limitresults>50</limitresults> </preferences> </ServiceRequest> Qualys Asset Management and Tagging API 11

Chapter 1 Welcome Usage Limit your results Use the optional fields parameter for any Search or Get API request to limit the amount of information returned in the results. Simply specify the fields you want to include in the output, and all other information will be filtered out. Multiple fields are comma separated and wildcards are supported. Example - Get Request This get request will fetch tag ID 12345 and return the tag ID, name and creation date. https://qualysapi.qualys.com/qps/rest/2.0/get/am/tag/12345?fields= id,name,created Example - Search Request This search request will return the ID of the connector and the ID of any default tags attached to the connector: https://qualysapi.qualys.com/qps/rest/2.0/search/am/awsassetdataco nnector?fields=id,defaulttags.list.simpletag.id Using wildcards, the example above could be represented as: https://qualysapi.qualys.com/qps/rest/2.0/search/am/awsassetdataco nnector?fields=id,defaulttags.*.*.id 12 Qualys Asset Management and Tagging API

2 Tag API The Tags API provides a suite of API functions for managing tags. The supported Tag operations are get, create, update, search, count, delete and evaluate. Operations Get Tag Info Create Tag Update Tag Search Tags Count Tags Delete Tag Evaluate Tag Reference Tag Fields

Chapter 2 Tag API Get Tag Info Get Tag Info Returns a single tag by ID. URL Method Limit your results https://<baseurl>/qps/rest/2.0/get/am/tag/<id> GET Use the optional fields parameter to limit the amount of information returned for the tag. Learn more Permissions Managers with Full Scope Users without Full Scope must have these account permissions: - Access Permission API Access Example Fetch tag ID 12345. Request: curl -n -u "USERNAME:PASSWORD" "https://qualysapi.qualys.com/qps/rest/2.0/get/am/tag/12345" Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/tag.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <Tag> <id>12345</id> <name>test Tag</name> <created>2014-02-06t19:14:50z</created> <modified>2014-02-06t19:14:50z</modified> <color>#ffffff</color> <ruletext>asset.installedsoftwares.contains { it.name == "Windows" }</ruletext> 14 Qualys Asset Management and Tagging API

Chapter 2 Tag API Get Tag Info <ruletype>groovy</ruletype> <children> <list/> </children> </Tag> </data> </ServiceResponse> Qualys Asset Management and Tagging API 15

Chapter 2 Tag API Create Tag Create Tag Create a new tag and possibly child tags. URL Method https://<baseurl>/qps/rest/2.0/create/am/tag POST Permissions Managers with Full Scope Users without Full Scope must have these account permissions: - Access Permission API Access - Tag Permission Create User Tag - Tag Permission Modify Dynamic Tag Rules (to create a dynamic tag) Example This example creates a new tag and 3 child tags. Request: curl -u "USERNAME:PASSWORD" -H "Content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/create/am/tag" < file.xml Note: file.xml contains the request POST data. Request POST data (file.xml): <?xml version="1.0" encoding="utf-8"?> <ServiceRequest> <data> <Tag> <name>parent Tag</name> <ruletype>groovy</ruletype> <ruletext>if(asset.getassettype()!=asset.assettype.host) return false; return asset.hasvulnswithseverity(4,5)</ruletext> <created>2014-02-06t19:14:50z</created> <modified>2014-02-06t19:14:50z</modified> <color>#ffffff</color> <children> 16 Qualys Asset Management and Tagging API

Chapter 2 Tag API Create Tag <set> <TagSimple> <name>child 1</name> </TagSimple> <TagSimple> <name>child 2</name> </TagSimple> <TagSimple> <name>child 3</name> </TagSimple> </set> </children> </Tag> </data> </ServiceRequest> Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/tag.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <Tag> <id>1589217</id> <name>parent Tag</name> <created>2014-02-06t19:14:50z</created> <modified>2014-02-06t19:14:50z</modified> <color>#ffffff</color> <ruletext>if(asset.getassettype()!=asset.assettype.host) return false; return asset.hasvulnswithseverity(4,5)</ruletext> <ruletype>groovy</ruletype> <children> <list> <TagSimple> <id>1</id> <name>child 1</name> </TagSimple> Qualys Asset Management and Tagging API 17

Chapter 2 Tag API Create Tag <TagSimple> <id>2</id> <name>child 2</name> </TagSimple> <TagSimple> <id>3</id> <name>child 3</name> </TagSimple> </list> </children> </Tag> </data> </ServiceResponse> Get to know Groovy Check out the following article on our Community to learn how to create asset tags using the Groovy programming language. You ll also get several Groovy rule examples that you can start using today. From our Community Create Asset Tags using Groovy 18 Qualys Asset Management and Tagging API

Chapter 2 Tag API Update Tag Update Tag Update fields for a tag and collections of tags. URL Method https://<baseurl>/qps/rest/2.0/update/am/tag/<id> or https://<baseurl>/qps/rest/2.0/update/am/tag POST Permissions Managers with Full Scope Users without Full Scope must have these account permissions: - Access Permission API Access - Tag Permission Edit User Tag - Tag Permission Modify Dynamic Tag Rules (to update a dynamic tag) Example Request 1: This example renames parent tag 12345 and removes some of its child tags. curl -u "USERNAME:PASSWORD" -H "Content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/update/am/tag/12345" < file.xml Note: file.xml contains the request POST data. Request POST data (file.xml): <?xml version="1.0" encoding="utf-8"?> <ServiceRequest> <data> <Tag> <name>parent Tag (Updated)</name> <children> <remove> <TagSimple><id>123</id></TagSimple> <TagSimple><id>456</id></TagSimple> </remove> </children> Qualys Asset Management and Tagging API 19

Chapter 2 Tag API Update Tag </Tag> </data> </ServiceRequest> Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/tag.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <Tag> <id>12345</id> <name>tag</name> <created>2014-02-06t19:14:50z</created> <modified>2014-02-06t19:14:50z</modified> <color>#ffffff</color> <ruletext>asset.installedsoftwares.contains { it.name == "Windows" }</ruletext> <ruletype>groovy</ruletype> <children> <list> <TagSimple> <id>1</id> <name>child 1</name> </TagSimple> <TagSimple> <id>2</id> <name>child 2</name> </TagSimple> <TagSimple> <id>3</id> <name>child 3</name> </TagSimple> <TagSimple> <id>123</id> <name>linked Child 1</name> </TagSimple> <TagSimple> 20 Qualys Asset Management and Tagging API

Chapter 2 Tag API Update Tag <id>456</id> <name>linked Child 2</name> </TagSimple> </list> </children> </Tag> </data> </ServiceResponse> Request 2: This example adds a child tag to tags that have color equal to #FF0000. curl -u "USERNAME:PASSWORD" -H "Content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/update/am/tag" < file.xml Note: file.xml contains the request POST data. Request POST data (file.xml): <?xml version="1.0" encoding="utf-8"?> <ServiceRequest> <filters> <Criteria field="color" operator="equals">#ff0000</criteria> <filters> <data> <Tag> <children> <add> <TagSimple><id>123</id></TagSimple> </add> </children> </Tag> </data> </ServiceRequest> Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/tag.xsd"> Qualys Asset Management and Tagging API 21

Chapter 2 Tag API Update Tag <responsecode>success</responsecode> <count>2</count> <data> <Tag> <id>12345</id> <name>tag</name> <created>2014-02-06t19:14:50z</created> <modified>2014-02-06t19:14:50z</modified> <color>#ff0000</color> <ruletext>asset.installedsoftwares.contains { it.name == "Windows" }</ruletext> <ruletype>groovy</ruletype> <children> <list> <SimpleTag> <id>123</id> <name>red</name> </SimpleTag> <list> </children> </Tag> <Tag> <id>12346</id> <name>another Red Tag</name> <created>2014-02-06t19:14:50z</created> <modified>2014-02-06t19:14:50z</modified> <color>#ff0000</color> <ruletext>asset.installedsoftwares.contains { it.name == "Windows" }</ruletext> <ruletype>groovy</ruletype> <children> <list> <SimpleTag> <id>123</id> <name>red</name> </SimpleTag> <list> </children> </Tag> </data> </ServiceResponse> 22 Qualys Asset Management and Tagging API

Chapter 2 Tag API Search Tags Search Tags Returns a list of tags that match the provided criteria. URL Method Pagination Limit your results https://<baseurl>/qps/rest/2.0/search/am/tag POST A maximum of 100 tags are returned by default. To customize this specify a preferences tag in the POST body of your request. Use the optional fields parameter to limit the amount of information returned for each tag. Learn more Searchable Fields These fields can be used to search for tags. id (long) name (string) parenttagid (long) ruletype (STATIC, GROOVY, OS_REGEX, NETWORK_RANGE, NAME_CONTAINS, INSTALLED_SOFTWARE, OPEN_PORTS, VULN_EXIST, ASSET_SEARCH) color (string formatted as #FFFFFF where F can be any value between 0-9 and A-F) Permissions Managers with Full Scope Users without Full Scope must have this account permission: - Access Permission API Access Qualys Asset Management and Tagging API 23

Chapter 2 Tag API Search Tags Example Find all tags with Groovy Script tag rules. Request: curl -u "USERNAME:PASSWORD" -H "content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/search/am/tag" < file.xml Request POST data (file.xml): <ServiceRequest> <filters> <Criteria field="ruletype" operator="equals">groovy</criteria> </filters> </ServiceRequest> Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/tag.xsd"> <responsecode>success</responsecode> <count>2</count> <data> <Tag> <id>12345</id> <name>tag</name> <created>2014-02-06t19:14:50z</created> <modified>2014-02-06t19:14:50z</modified> <color>#ff0000</color> <ruletext>asset.installedsoftwares.contains { it.name == "Windows" }</ruletext> <ruletype>groovy</ruletype> <children> <list> <SimpleTag> <id>123</id> <name>red</name> </SimpleTag> 24 Qualys Asset Management and Tagging API

Chapter 2 Tag API Search Tags <list> </children> </Tag> <Tag> <id>12346</id> <name>another Red Tag</name> <created>2014-02-06t19:14:50z</created> <modified>2014-02-06t19:14:50z</modified> <color>#ff0000</color> <ruletext>asset.installedsoftwares.contains { it.name == "Windows" }</ruletext> <ruletype>groovy</ruletype> <children> <list> <SimpleTag> <id>123</id> <name>red</name> </SimpleTag> <list> </children> </Tag> </data> </ServiceResponse> Qualys Asset Management and Tagging API 25

Chapter 2 Tag API Count Tags Count Tags Count all the children of a tag. URL Method https://<baseurl>/qps/rest/2.0/count/am/tag POST Permissions Managers with Full Scope Users without Full Scope must have this account permission: - Access Permission API Access Example Get a count of all the children of tag ID 12345 Request: curl -u "USERNAME:PASSWORD" -H "content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/count/am/tag" < file.xml Request POST data (file.xml): <ServiceRequest> <filters> <Criteria field="parent" operator="equals">12345</criteria> </filters> </ServiceRequest> Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/tag.xsd"> <responsecode>success</responsecode> <count>2</count> </ServiceResponse> 26 Qualys Asset Management and Tagging API

Chapter 2 Tag API Delete Tag Delete Tag Delete tags one or more tags. URL Method https://<baseurl>/qps/rest/2.0/delete/am/tag/<id> or https://<baseurl>/qps/rest/2.0/delete/am/tag POST Permissions Managers with Full Scope Users without Full Scope must have these account permissions: - Access Permission API Access - Tag Permission Delete User Tag Examples Delete the tag that has the ID 12345. Request: curl -u "USERNAME:PASSWORD" -H "content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/delete/am/tag/12345" Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/tag.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <SimpleTag> <id>12345</id> </SimpleTag> </data> </ServiceResponse> Qualys Asset Management and Tagging API 27

Chapter 2 Tag API Evaluate Tag Evaluate Tag Force re-evaluation of one or more tags. Assets will be tagged only if they match the tag rule and are visible to the user. The dynamic tag evaluation feature must be turned on for your subscription in order to run this API. URL Method https://<baseurl>/qps/rest/2.0/evaluate/am/tag/<id> or https://<baseurl>/qps/rest/2.0/evaluate/am/tag POST Permissions Managers with Full Scope Users without Full Scope must have this account permission: - Access Permission API Access Examples Evaluate all tags that have Groovy Script tag rules. Request: curl -u "USERNAME:PASSWORD" -H "content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/evaluate/am/tag" Request POST data (file.xml): <?xml version="1.0" encoding="utf-8"?> <ServiceRequest> <filters> <Criteria field="ruletype" operator="equals">groovy</criteria> </filters> </ServiceRequest> Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs 28 Qualys Asset Management and Tagging API

Chapter 2 Tag API Evaluate Tag d/2.0/am/tag.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <Tag> <id>12345</id> <name>tag</name> <created>2014-02-06t19:14:50z</created> <modified>2014-02-06t19:14:50z</modified> <color>#ff0000</color> <ruletext>asset.installedsoftwares.contains { it.name == "Windows" }</ruletext> <ruletype>groovy</ruletype> <children> <list> <SimpleTag> <id>123</id> <name>red</name> </SimpleTag> <list> </children> </Tag> </data> </ServiceResponse> Qualys Asset Management and Tagging API 29

Chapter 2 Tag API Tag Fields Tag Fields Writable parentidtag (long) color (string) ruletext (string) srcassetgroupid (long) srcbusinessunitid (long) srcoperatingsystemname (string) children (TagSimpleQList) Read only created (date) modified (date) Associations TagSimpleQList - Asset tags on the associated asset. This collection to be added to and removed from is provided as a tag ID wrapped in a TagSimple element. TagSimple id name long (tag primary key) string (tag name) 30 Qualys Asset Management and Tagging API

3 Host Asset API The Host Asset API provides a suite of API functions for managing host assets. In many cases these are hosts detected by our cloud scanners. Host assets can also be added manually by the Qualys API or user interface. The HostAsset members identify operating system, NetBIOS, tags, open ports, NICs, installed software, EC2 source information and current vulnerabilities (all instances). Operations Get Host Asset Info Create Host Asset Update Host Asset Search Hosts Assets Count Host Assets Delete Host Asset Activate Host Asset Reference Host Asset Fields

Chapter 3 Host Asset API Get Host Asset Info Get Host Asset Info Returns a single host asset by ID. URL Method Limit your results https://<baseurl>/qps/rest/2.0/get/am/hostasset/<id> GET Use the optional fields parameter to limit the amount of information returned for the host asset. Learn more Permissions Managers with Full Scope Users without Full Scope must have these account settings: 1) scope includes the requested asset, and 2) permissions include: - Access Permission API Access - Asset Management Permission Read Asset Example Fetch the host asset ID 12345 and list host asset details. Request: curl -n -u "USERNAME:PASSWORD" "https://qualysapi.qualys.com/qps/rest/2.0/get/am/hostasset/12345" Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/hostasset.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <HostAsset> <id>2020094</id> <name>my Windows Asset</name> <created>2014-02-06t19:16:35z</created> <modified>2014-02-06t19:16:35z</modified> <type>host</type> 32 Qualys Asset Management and Tagging API

Chapter 3 Host Asset API Get Host Asset Info <tags> <list> <TagSimple> <id>12345</id> <name>tag 1</name> </TagSimple> <TagSimple> <id>54321</id> <name>tag 2</name> </TagSimple> </list> </tags> <sourceinfo> <list/> </sourceinfo> <os>windows 7</os> <dnshostname>localhost</dnshostname> <netbiosname>test</netbiosname> <netbiosnetworkid>10</netbiosnetworkid> <networkguid>66bf43c8-7392-4257-b856- a320fde231eb</networkguid> <address>127.0.0.1</address> <trackingmethod>ip</trackingmethod> <openport> <list/> </openport> <software> <list/> </software> <vuln> <list/> </vuln> </HostAsset> </data> </ServiceResponse> Qualys Asset Management and Tagging API 33

Chapter 3 Host Asset API Create Host Asset Create Host Asset Create a host asset using writable fields and collections. It is a good idea to attach tags that will make the asset visible to the current user if that user does not have permission to see all assets. Otherwise, the asset will be created, but the users will not be able to see or modify it until an administrator or process attaches the appropriate tags. What s next? Once you ve created a new host asset you need to activate the asset in order to make it available for scanning and reporting in the Vulnerability Management (VM) application module. See Activate Host Asset. URL Method https://<baseurl>/qps/rest/2.0/create/am/hostasset POST Permissions Managers with Full Scope Users without Full Scope must have these account permissions: - Access Permission API Access - Asset Management Permission Create Asset Example This example creates a new host asset with tags assigned. Request: curl -u "USERNAME:PASSWORD" -H "Content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/create/am/hostasset" < file.xml Note: file.xml contains the request POST data. Request POST data (file.xml): <?xml version="1.0" encoding="utf-8"?> <ServiceRequest> <data> <HostAsset> <name>my Windows Asset</name> <os>windows 7</os> <dnshostname>localhost</dnshostname> <netbiosname>test</netbiosname> 34 Qualys Asset Management and Tagging API

Chapter 3 Host Asset API Create Host Asset <netbiosnetworkid>10</netbiosnetworkid> <networkguid>66bf43c8-7392-4257-b856- a320fde231eb</networkguid> <address>127.0.0.1</address> <trackingmethod>ip</trackingmethod> <tags> <set> <TagSimple><id>12345</id></TagSimple> <TagSimple><id>54321</id></TagSimple> </set> </tags> <software> <set> <HostAssetSoftware> <name>photoshop</name> <version>9</version> </HostAssetSoftware> </set> </software> </HostAsset> </data> </ServiceRequest> Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/hostasset.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <HostAsset> <id>2020094</id> <name>my Windows Asset</name> <created>2014-02-06t19:16:35z</created> <modified>2014-02-06t19:16:35z</modified> <type>host</type> <tags> <list> <TagSimple> Qualys Asset Management and Tagging API 35

Chapter 3 Host Asset API Create Host Asset <id>12345</id> <name>tag 1</name> </TagSimple> <TagSimple> <id>54321</id> <name>tag 2</name> </TagSimple> </list> </tags> <sourceinfo> <list/> </sourceinfo> <os>windows 7</os> <dnshostname>localhost</dnshostname> <netbiosname>test</netbiosname> <netbiosnetworkid>10</netbiosnetworkid> <networkguid>66bf43c8-7392-4257-b856- a320fde231eb</networkguid> <address>127.0.0.1</address> <trackingmethod>ip</trackingmethod> <openport> <list/> </openport> <software> <list/> </software> <vuln> <list/> </vuln> </HostAsset> </data> </ServiceResponse> 36 Qualys Asset Management and Tagging API

Chapter 3 Host Asset API Update Host Asset Update Host Asset Update fields for a host asset and collections of host assets.. URL Method https://<baseurl>/qps/rest/2.0/update/am/hostasset/<id > or https://<baseurl>/qps/rest/2.0/update/am/hostasset POST Permissions Managers with Full Scope Users without Full Scope must have these account settings: 1) scope includes the requested asset(s), and 2) permissions include: - Access Permission API Access - Asset Management Permission Update Asset Example Request 1: Update some of the fields for host asset ID 12345. curl -u "USERNAME:PASSWORD" -H "Content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/update/am/hostasset/123 45" < file.xml Note: file.xml contains the request POST data. Request POST data (file.xml): <?xml version="1.0" encoding="utf-8"?> <ServiceRequest> <Asset><data> <HostAsset> <name>updated Name</name> <os>windows 95</os> <dnshostname>win95.old.corp.net</dnshostname> </HostAsset> </data> </ServiceRequest> Qualys Asset Management and Tagging API 37

Chapter 3 Host Asset API Update Host Asset Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/hostasset.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <HostAsset> <id>2020094</id> <name>updated Name</name> <os>windows 95</os> <dnshostname>win95.old.corp.net</dnshostname> <created>2014-02-06t19:16:35z</created> <modified>2014-02-06t19:16:35z</modified> <type>host</type> <tags> <list /> </tags> <sourceinfo> <list/> </sourceinfo> <netbiosname>test</netbiosname> <netbiosnetworkid>10</netbiosnetworkid> <networkguid>66bf43c8-7392-4257-b856- a320fde231eb</networkguid> <address>127.0.0.1</address> <trackingmethod>ip</trackingmethod> <openport> <list/> </openport> <software> <list/> </software> <vuln> <list/> </vuln> </HostAsset> </data> </ServiceResponse> 38 Qualys Asset Management and Tagging API

Chapter 3 Host Asset API Update Host Asset Request 2: Update some of the fields for host assets that have names containing the word OLD. curl -u "USERNAME:PASSWORD" -H "Content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/update/am/hostasset" < file.xml Note: file.xml contains the request POST data. Request POST data (file.xml): <?xml version="1.0" encoding="utf-8"?> <ServiceRequest> <filters> <Criteria field="name" operator="contains">old</criteria> </filters> <data> <HostAsset> <tags> <add> <TagSimple><id>12345</id></TagSimple> <add> <remove> <TagSimple><id>54321</id><TagSimple> </remove> </tags> <software> <set> <HostAssetSoftware> <name>windows</name> <version>95</name> </HostAssetSoftware> </set> </software> <openport> <add> <HostAssetOpenPort> <port>8080</port> <protocol>tcp</protocol> </HostAssetOpenPort> </add> </openport> Qualys Asset Management and Tagging API 39

Chapter 3 Host Asset API Update Host Asset </HostAsset> </data> </ServiceRequest> Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/hostasset.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <HostAsset> <id>2020094</id> <name>updated Name</name> <os>windows 95</os> <dnshostname>win95.old.corp.net</dnshostname> <created>2014-02-06t19:16:35z</created> <modified>2014-02-06t19:16:35z</modified> <type>host</type> <tags> <list> <TagSimple> <id>12345</id> <name>simple Tag 1</name> </TagSimple> </list> </tags> <sourceinfo> <list/> </sourceinfo> <netbiosname>test</netbiosname> <netbiosnetworkid>10</netbiosnetworkid> <networkguid>66bf43c8-7392-4257-b856- a320fde231eb</networkguid> <address>127.0.0.1</address> <trackingmethod>ip</trackingmethod> <openport> <list> <HostAssetOpenPort> 40 Qualys Asset Management and Tagging API

Chapter 3 Host Asset API Update Host Asset <port>8080</port> <protocol>tcp</protocol> </HostAssetOpenPort> </list> </openport> <software> <list> <HostAssetSoftware> <name>windows</name> <version>95</version> </HostAssetSoftware> </list> </software> <vuln> <list/> </vuln> </HostAsset> </data> </ServiceResponse> Qualys Asset Management and Tagging API 41

Chapter 3 Host Asset API Search Hosts Assets Search Hosts Assets Returns a list of host assets matching the provided criteria. Assets are returned when they are visible to the user (i.e. in the user s scope). URL Method Pagination Limit your results https://<baseurl>/qps/rest/2.0/search/am/hostasset POST A maximum of 100 host assets are returned by default. To customize this specify a preferences tag in the POST body of your request. Use the optional fields parameter to limit the amount of information returned for each host asset. Learn more Searchable Fields These fields can be used to search for host assets. qwebhostid (long) lastvulnscan (date) lastcompliancescan (date) informationgatheredupdate d (date) os (string) dnshostname (string) netbiosname (string) netbiosnetworkid (string) networdguid (string) trackingmethod (AssetTrackingMethod) port (integer) installedsoftware (string) Permissions Managers with Full Scope Users without Full Scope must have these account permissions: - Access Permission API Access - Asset Management Permission Read Asset 42 Qualys Asset Management and Tagging API

Chapter 3 Host Asset API Search Hosts Assets Example Find host assets with a Windows operating system that are tracked by Instance ID. Request: curl -u "USERNAME:PASSWORD" -H "content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/search/am/hostasset" < file.xml Request POST data (file.xml): <ServiceRequest> <filters> <Criteria field="os" operator="equals">windows</criteria> <Criteria field="trackingmethod" operator="equals">instance_id</criteria> </filters> </ServiceRequest> Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/hostasset.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <HostAsset> <id>2020094</id> <name>updated Name</name> <os>windows</os> <dnshostname>win95.old.corp.net</dnshostname> <created>2014-02-06t19:16:35z</created> <modified>2014-02-06t19:16:35z</modified> <type>host</type> <tags> <list /> </tags> <sourceinfo> <list/> </sourceinfo> <netbiosname>test</netbiosname> Qualys Asset Management and Tagging API 43

Chapter 3 Host Asset API Search Hosts Assets <netbiosnetworkid>10</netbiosnetworkid> <networkguid>66bf43c8-7392-4257-b856- a320fde231eb</networkguid> <address>127.0.0.1</address> <trackingmethod>instance_id</trackingmethod> <openport> <list/> </openport> <software> <list/> </software> <vuln> <list/> </vuln> </HostAsset> </data> </ServiceResponse> 44 Qualys Asset Management and Tagging API

Chapter 3 Host Asset API Count Host Assets Count Host Assets Returns the number of host assets that match the provided criteria. A host asset is counted when the asset is visible to the user (i.e. it is in the user s scope). URL Method https://<baseurl>/qps/rest/2.0/count/am/hostasset GET Permissions Managers with Full Scope Users without Full Scope must have these account permissions: - Access Permission API Access - Asset Management Permission Read Asset Example Request: curl -u "USERNAME:PASSWORD" "https://qualysapi.qualys.com/qps/rest/2.0/count/am/hostasset" Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/hostasset.xsd"> <responsecode>success</responsecode> <count>548</count> </ServiceResponse> Qualys Asset Management and Tagging API 45

Chapter 3 Host Asset API Delete Host Asset Delete Host Asset Delete one or more host assets. URL Method https://<baseurl>/qps/rest/2.0/delete/am/hostasset/<id> or https://<baseurl>/qps/rest/2.0/delete/am/hostasset POST Permissions Managers with Full Scope Users without Full Scope must have these account settings: 1) scope includes the requested asset(s), and 2) permissions include: - Access Permission API Access - Asset Management Permission Delete Asset Example Delete host assets with the tag To Delete. Request: curl -u "USERNAME:PASSWORD" -H "content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/delete/am/hostasset" < file.xml Note: file.xml contains the request POST data. Request POST data (file.xml): <?xml version="1.0" encoding="utf-8"?> <ServiceRequest> <filters> <Criteria field="tagname" operator="equals">to Delete</Criteria> </filters> </ServiceRequest> Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschema- 46 Qualys Asset Management and Tagging API

Chapter 3 Host Asset API Delete Host Asset instance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/hostasset.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <HostAsset> <id>2020094</id> </HostAsset> </data> </ServiceResponse> Qualys Asset Management and Tagging API 47

Chapter 3 Host Asset API Activate Host Asset Activate Host Asset Activate one or more assets to make them available in your account for scanning and reporting. You ll want to activate newly created hosts to make them available in the Vulnerability Management (VM) application module and/or the Policy Compliance (PC) module. URL for VM assets URL for PC assets Method https://<baseurl>/qps/rest/2.0/activate/am/hostasset/<id>?module=qweb_vm or https://<baseurl>/qps/rest/2.0/activate/am/hostasset?mod ule=qweb_vm https://<baseurl>/qps/rest/2.0/activate/am/hostasset/<id>?module=qweb_pc or https://<baseurl>/qps/rest/2.0/activate/am/hostasset?mod ule=qweb_pc POST Permissions Managers with Full Scope Users without Full Scope must have these account settings: 1) scope includes the requested asset(s), and 2) permissions include: - Access Permission API Access For PC assets, the Policy Compliance (PC) module must be enabled Example Activate the host assets with the tag Export to VM. Request: curl -u "USERNAME:PASSWORD" -H "content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/activate/am/hostasset" < file.xml Note: file.xml contains the request POST data. 48 Qualys Asset Management and Tagging API

Chapter 3 Host Asset API Activate Host Asset Request POST data (file.xml): <?xml version="1.0" encoding="utf-8"?> <ServiceRequest> <filters> <Criteria field="tagname" operator="equals">export to VM</Criteria> </filters> </ServiceRequest> See also Activate Asset Qualys Asset Management and Tagging API 49

Chapter 3 Host Asset API Host Asset Fields Host Asset Fields Writable os (string) dnshostname (string) netbiosname (string) netbiosnetworkid (integer) networkguid (uuid) address (string) trackingmethod (AssetTrackingMethod: NONE, IP, DNSNAME, NETBIOS, INSTANCE_ID) openport (HostAssetOpenPortQList) software (HostAssetSoftwareQList) Read only qwebhostid (long) lastvulnscan (date) lastcompliancescan (date) vulnsupdated (date) informationgatheredupdated (date) Associations HostAssetOpenPortQList - Open ports (HostAssetOpenPortList) detected or explicitly added to the asset. This collection is keyed off of the port and protocol. HostAssetOpenPortList port protocol serviceid servername integer Protocol (TCP, UDP, ICMP) integer string (name of the service detected on the port - read only) 50 Qualys Asset Management and Tagging API

Chapter 3 Host Asset API Host Asset Fields HostAssetSoftwareQList - A list of software (HostAssetSoftware) installed on the machine, keyed on the name. HostAssetSoftware name (string) version (string) HostAssetVulnQList - A list of vulnerabilities detected on the host. Only vulnerabilities flagged as found will be returned. More detailed information about each detected vulnerability can be obtained from the HostInstanceVuln resource, cross referenced by the hostinstancevulnid field. The HostInstanceVuln can also be used to find previously detected vulnerabilities that are currently marked as not found. HostInstanceVuln qid (long) hostinstancevulnid (long) firstfound (date) lastfound (date) Qualys Asset Management and Tagging API 51

Chapter 3 Host Asset API Host Asset Fields 52 Qualys Asset Management and Tagging API

4 Asset API The Asset API is a subset of the Host Asset API. The Asset members identify name, tags, and EC2 source information. Operations Get Asset Info Update Asset Search Assets Count Assets Delete Asset Activate Asset Reference Asset Fields

Chapter 4 Asset API Get Asset Info Get Asset Info Returns a single asset by ID. URL Method Limit your results https://<baseurl>/qps/rest/2.0/get/am/asset/<id> GET Use the optional fields parameter to limit the amount of information returned for the asset. Learn more Permissions Managers with Full Scope Users without Full Scope must have these account settings: 1) scope includes the requested asset, and 2) permissions include: - Access Permission API Access - Asset Management Permission Read Asset Example This example fetches the asset ID 12345 and lists asset details. Request: curl -n -u "USERNAME:PASSWORD" "https://qualysapi.qualys.com/qps/rest/2.0/get/am/asset/12345" Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/asset.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <Asset> <id>12345</id> <name>my Windows Asset</name> <created>2014-02-06t19:16:35z</created> <modified>2014-02-06t19:16:35z</modified> <type>host</type> 54 Qualys Asset Management and Tagging API

Chapter 4 Asset API Get Asset Info <tags> <list> <TagSimple> <id>12345</id> <name>tag 1</name> </TagSimple> <TagSimple> <id>54321</id> <name>tag 2</name> </TagSimple> </list> </tags> </Asset> </data> </ServiceResponse> Qualys Asset Management and Tagging API 55

Chapter 4 Asset API Update Asset Update Asset Update fields for an asset and collections of assets. Only the name and tags can be modified. URL Method https://<baseurl>/qps/rest/2.0/update/am/asset/<id> or https://<baseurl>/qps/rest/2.0/update/am/asset POST Permissions Managers with Full Scope Users without Full Scope must have these account settings: 1) scope includes the requested asset(s), and 2) permissions include: - Access Permission API Access - Asset Management Permission Update Asset Example Request 1: Update tag 12345 and give it another name. curl -u "USERNAME:PASSWORD" -H "Content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/update/am/asset/12345" < file.xml Note: file.xml contains the request POST data. Request POST data (file.xml): <?xml version="1.0" encoding="utf-8"?> <ServiceRequest> <data> <Asset> <name>updated Name</name> </Asset> </data> </ServiceRequest> 56 Qualys Asset Management and Tagging API

Chapter 4 Asset API Update Asset Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/asset.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <Asset> <id>12345</id> <name>updated Name</name> <created>2014-02-06t19:16:35z</created> <modified>2014-02-06t19:16:35z</modified> <type>host</type> <tags> <list> <TagSimple> <id>12345</id> <name>tag 1</name> </TagSimple> <TagSimple> <id>54321</id> <name>tag 2</name> </TagSimple> </list> </tags> </Asset> </data> </ServiceResponse> Request 2: Update tags that have tag names containing the word DELETED. curl -u "USERNAME:PASSWORD" -H "Content-type: text/xml" -X "POST" --data-binary @- "https://qualysapi.qualys.com/qps/rest/2.0/update/am/asset" < file.xml Note: file.xml contains the request POST data. Qualys Asset Management and Tagging API 57

Chapter 4 Asset API Update Asset Request POST data (file.xml): <?xml version="1.0" encoding="utf-8"?> <ServiceRequest> <filters> <Criteria field="name" operator="contains">deleted</criteria> <filters> <data> <Asset> <tags> <add> <TagSimple><id>12345</id></TagSimple> <add> </tags> </Asset> </data> </ServiceRequest> Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/asset.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <Asset> <id>543</id> <name>old Asset (DELETED)</name> <created>2014-02-06t19:16:35z</created> <modified>2014-02-06t19:16:35z</modified> <type>host</type> <tags> <list> <TagSimple> <id>12345</id> <name>tag 1</name> </TagSimple> </list> </tags> </Asset> 58 Qualys Asset Management and Tagging API

Chapter 4 Asset API Update Asset </data> </ServiceResponse> Qualys Asset Management and Tagging API 59

Chapter 4 Asset API Search Assets Search Assets Returns a list of assets matching the provided criteria. Assets are returned when they are visible to the user (i.e. in the user s scope). URL Method Pagination Limit your results https://<baseurl>/qps/rest/2.0/search/am/asset POST A maximum of 100 assets are returned by default. To customize this specify a preferences tag in the POST body of your request. Use the optional fields parameter to limit the amount of information returned for each asset. Learn more Searchable Fields These fields can be used to search for assets. id (long) name (string) created (date) updated (date) type (UNKOWN, HOST, SCANNER, WEBAPP, MALWARE_DOMAIN) tagname (string) tagid (string) solrquery (string, an asset solr query) For tagname and tagid, parents of the tag will also match. For example if tag A had child tag B and an asset has tag A, then a search for tag B will return assets with tags A and B. Permissions Managers with Full Scope Users without Full Scope must have these account permissions: - Access Permission API Access - Asset Management Permission Read Asset Example Find an asset with a particular tag. Request: curl -u "USERNAME:PASSWORD" -H "content-type: text/xml" -X "POST" --data-binary @- 60 Qualys Asset Management and Tagging API

Chapter 4 Asset API Search Assets "https://qualysapi.qualys.com/qps/rest/2.0/search/am/asset" < file.xml Request POST data (file.xml): <ServiceRequest> <filters> <Criteria field="tagname" operator="equals">to Delete</Criteria> </filters> </ServiceRequest> Response: <?xml version="1.0" encoding="utf-8"?> <ServiceResponse xmlns:xsi="http://www.w3.org/2001/xmlschemainstance" xsi:nonamespaceschemalocation="https://qualysapi.qualys.com/qps/xs d/2.0/am/asset.xsd"> <responsecode>success</responsecode> <count>1</count> <data> <Asset> <id>543</id> <name>old Asset (To Delete)</name> <created>2014-02-06t19:16:35z</created> <modified>2014-02-06t19:16:35z</modified> <type>host</type> <tags> <list> <TagSimple> <id>12345</id> <name>tag 1</name> </TagSimple> </list> </tags> </Asset> </data> </ServiceResponse> Qualys Asset Management and Tagging API 61