DescribeFindings Python Example
import sys
import chilkat
# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
rest = chilkat.CkRest()
authAws = chilkat.CkAuthAws()
authAws.put_AccessKey("AWS_ACCESS_KEY")
authAws.put_SecretKey("AWS_SECRET_KEY")
# Don't forget to change the region to your particular region. (Also make the same change in the call to Connect below.)
authAws.put_Region("us-west-2")
authAws.put_ServiceName("inspector")
# SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
rest.SetAuthAws(authAws)
# URL: https://inspector.us-west-2.amazonaws.com/
# Use the same region as specified above.
success = rest.Connect("inspector.us-west-2.amazonaws.com",443,True,True)
if (success != True):
print("ConnectFailReason: " + str(rest.get_ConnectFailReason()))
print(rest.lastErrorText())
sys.exit()
# The following code creates the JSON request body.
# The JSON created by this code is shown below.
# Use this online tool to generate code from sample JSON:
# Generate Code to Create JSON
json = chilkat.CkJsonObject()
json.UpdateString("findingArns[0]","string")
json.UpdateString("locale","string")
# The JSON request body created by the above code:
# {
# "findingArns": [
# "string"
# ],
# "locale": "string"
# }
rest.AddHeader("Content-Type","application/x-amz-json-1.1")
rest.AddHeader("X-Amz-Target","InspectorService.DescribeFindings")
sbRequestBody = chilkat.CkStringBuilder()
json.EmitSb(sbRequestBody)
sbResponseBody = chilkat.CkStringBuilder()
success = rest.FullRequestSb("POST","/",sbRequestBody,sbResponseBody)
if (success != True):
print(rest.lastErrorText())
sys.exit()
respStatusCode = rest.get_ResponseStatusCode()
print("response status code = " + str(respStatusCode))
if (respStatusCode != 200):
print("Response Header:")
print(rest.responseHeader())
print("Response Body:")
print(sbResponseBody.getAsString())
sys.exit()
jResp = chilkat.CkJsonObject()
jResp.LoadSb(sbResponseBody)
# The following code parses the JSON response.
# A sample JSON response is shown below the sample code.
# Use this online tool to generate parsing code from sample JSON:
# Generate Parsing Code from JSON
FailureCode = jResp.stringOf("failedItems.string.failureCode")
Retryable = jResp.IntOf("failedItems.string.retryable")
i = 0
count_i = jResp.SizeOfArray("findings")
while i < count_i :
jResp.put_I(i)
arn = jResp.stringOf("findings[i].arn")
AgentId = jResp.stringOf("findings[i].assetAttributes.agentId")
AmiId = jResp.stringOf("findings[i].assetAttributes.amiId")
AutoScalingGroup = jResp.stringOf("findings[i].assetAttributes.autoScalingGroup")
Hostname = jResp.stringOf("findings[i].assetAttributes.hostname")
SchemaVersion = jResp.IntOf("findings[i].assetAttributes.schemaVersion")
assetType = jResp.stringOf("findings[i].assetType")
confidence = jResp.IntOf("findings[i].confidence")
createdAt = jResp.IntOf("findings[i].createdAt")
description = jResp.stringOf("findings[i].description")
id = jResp.stringOf("findings[i].id")
indicatorOfCompromise = jResp.IntOf("findings[i].indicatorOfCompromise")
numericSeverity = jResp.IntOf("findings[i].numericSeverity")
recommendation = jResp.stringOf("findings[i].recommendation")
schemaVersion = jResp.IntOf("findings[i].schemaVersion")
service = jResp.stringOf("findings[i].service")
AssessmentRunArn = jResp.stringOf("findings[i].serviceAttributes.assessmentRunArn")
RulesPackageArn = jResp.stringOf("findings[i].serviceAttributes.rulesPackageArn")
serviceAttributesSchemaVersion = jResp.IntOf("findings[i].serviceAttributes.schemaVersion")
severity = jResp.stringOf("findings[i].severity")
title = jResp.stringOf("findings[i].title")
updatedAt = jResp.IntOf("findings[i].updatedAt")
j = 0
count_j = jResp.SizeOfArray("findings[i].assetAttributes.ipv4Addresses")
while j < count_j :
jResp.put_J(j)
strVal = jResp.stringOf("findings[i].assetAttributes.ipv4Addresses[j]")
j = j + 1
j = 0
count_j = jResp.SizeOfArray("findings[i].assetAttributes.networkInterfaces")
while j < count_j :
jResp.put_J(j)
networkInterfaceId = jResp.stringOf("findings[i].assetAttributes.networkInterfaces[j].networkInterfaceId")
privateDnsName = jResp.stringOf("findings[i].assetAttributes.networkInterfaces[j].privateDnsName")
privateIpAddress = jResp.stringOf("findings[i].assetAttributes.networkInterfaces[j].privateIpAddress")
publicDnsName = jResp.stringOf("findings[i].assetAttributes.networkInterfaces[j].publicDnsName")
publicIp = jResp.stringOf("findings[i].assetAttributes.networkInterfaces[j].publicIp")
subnetId = jResp.stringOf("findings[i].assetAttributes.networkInterfaces[j].subnetId")
vpcId = jResp.stringOf("findings[i].assetAttributes.networkInterfaces[j].vpcId")
k = 0
count_k = jResp.SizeOfArray("findings[i].assetAttributes.networkInterfaces[j].ipv6Addresses")
while k < count_k :
jResp.put_K(k)
strVal = jResp.stringOf("findings[i].assetAttributes.networkInterfaces[j].ipv6Addresses[k]")
k = k + 1
k = 0
count_k = jResp.SizeOfArray("findings[i].assetAttributes.networkInterfaces[j].privateIpAddresses")
while k < count_k :
jResp.put_K(k)
privateDnsName = jResp.stringOf("findings[i].assetAttributes.networkInterfaces[j].privateIpAddresses[k].privateDnsName")
privateIpAddress = jResp.stringOf("findings[i].assetAttributes.networkInterfaces[j].privateIpAddresses[k].privateIpAddress")
k = k + 1
k = 0
count_k = jResp.SizeOfArray("findings[i].assetAttributes.networkInterfaces[j].securityGroups")
while k < count_k :
jResp.put_K(k)
groupId = jResp.stringOf("findings[i].assetAttributes.networkInterfaces[j].securityGroups[k].groupId")
groupName = jResp.stringOf("findings[i].assetAttributes.networkInterfaces[j].securityGroups[k].groupName")
k = k + 1
j = j + 1
j = 0
count_j = jResp.SizeOfArray("findings[i].assetAttributes.tags")
while j < count_j :
jResp.put_J(j)
key = jResp.stringOf("findings[i].assetAttributes.tags[j].key")
value = jResp.stringOf("findings[i].assetAttributes.tags[j].value")
j = j + 1
j = 0
count_j = jResp.SizeOfArray("findings[i].attributes")
while j < count_j :
jResp.put_J(j)
key = jResp.stringOf("findings[i].attributes[j].key")
value = jResp.stringOf("findings[i].attributes[j].value")
j = j + 1
j = 0
count_j = jResp.SizeOfArray("findings[i].userAttributes")
while j < count_j :
jResp.put_J(j)
key = jResp.stringOf("findings[i].userAttributes[j].key")
value = jResp.stringOf("findings[i].userAttributes[j].value")
j = j + 1
i = i + 1
# A sample JSON response body parsed by the above code:
# {
# "failedItems": {
# "string": {
# "failureCode": "string",
# "retryable": boolean
# }
# },
# "findings": [
# {
# "arn": "string",
# "assetAttributes": {
# "agentId": "string",
# "amiId": "string",
# "autoScalingGroup": "string",
# "hostname": "string",
# "ipv4Addresses": [
# "string"
# ],
# "networkInterfaces": [
# {
# "ipv6Addresses": [
# "string"
# ],
# "networkInterfaceId": "string",
# "privateDnsName": "string",
# "privateIpAddress": "string",
# "privateIpAddresses": [
# {
# "privateDnsName": "string",
# "privateIpAddress": "string"
# }
# ],
# "publicDnsName": "string",
# "publicIp": "string",
# "securityGroups": [
# {
# "groupId": "string",
# "groupName": "string"
# }
# ],
# "subnetId": "string",
# "vpcId": "string"
# }
# ],
# "schemaVersion": number,
# "tags": [
# {
# "key": "string",
# "value": "string"
# }
# ]
# },
# "assetType": "string",
# "attributes": [
# {
# "key": "string",
# "value": "string"
# }
# ],
# "confidence": number,
# "createdAt": number,
# "description": "string",
# "id": "string",
# "indicatorOfCompromise": boolean,
# "numericSeverity": number,
# "recommendation": "string",
# "schemaVersion": number,
# "service": "string",
# "serviceAttributes": {
# "assessmentRunArn": "string",
# "rulesPackageArn": "string",
# "schemaVersion": number
# },
# "severity": "string",
# "title": "string",
# "updatedAt": number,
# "userAttributes": [
# {
# "key": "string",
# "value": "string"
# }
# ]
# }
# ]
# }