ListAnswers VB6 Example
' This example requires the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
Dim rest As New ChilkatRest
Dim success As Long
Dim authAws As New ChilkatAuthAws
authAws.AccessKey = "AWS_ACCESS_KEY"
authAws.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.Region = "us-west-2"
authAws.ServiceName = "wellarchitected"
' SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
success = rest.SetAuthAws(authAws)
' URL: https://wellarchitected.us-west-2.amazonaws.com/
' Use the same region as specified above.
success = rest.Connect("wellarchitected.us-west-2.amazonaws.com",443,1,1)
If (success <> 1) Then
Debug.Print "ConnectFailReason: " & rest.ConnectFailReason
Debug.Print rest.LastErrorText
Exit Sub
End If
success = rest.AddHeader("Content-Type","application/x-amz-json-1.1")
success = rest.AddHeader("X-Amz-Target","ListAnswers")
Dim sbResponseBody As New ChilkatStringBuilder
success = rest.FullRequestNoBodySb("GET","/workloads/{WorkloadId}/lensReviews/{LensAlias}/answers",sbResponseBody)
If (success <> 1) Then
Debug.Print rest.LastErrorText
Exit Sub
End If
Dim respStatusCode As Long
respStatusCode = rest.ResponseStatusCode
Debug.Print "response status code = " & respStatusCode
If (respStatusCode <> 200) Then
Debug.Print "Response Header:"
Debug.Print rest.ResponseHeader
Debug.Print "Response Body:"
Debug.Print sbResponseBody.GetAsString()
Exit Sub
End If
Dim jResp As New ChilkatJsonObject
success = 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
Dim IsApplicable As Long
Dim PillarId As String
Dim QuestionId As String
Dim QuestionTitle As String
Dim Reason As String
Dim Risk As String
Dim j As Long
Dim count_j As Long
Dim ChoiceId As String
Dim Status As String
Dim Description As String
Dim DisplayText As String
Dim v_Url As String
Dim ImprovementPlanDisplayText As String
Dim ImprovementPlanUrl As String
Dim Title As String
Dim strVal As String
Dim LensAlias As String
LensAlias = jResp.StringOf("LensAlias")
Dim LensArn As String
LensArn = jResp.StringOf("LensArn")
Dim MilestoneNumber As Long
MilestoneNumber = jResp.IntOf("MilestoneNumber")
Dim NextToken As String
NextToken = jResp.StringOf("NextToken")
Dim WorkloadId As String
WorkloadId = jResp.StringOf("WorkloadId")
Dim i As Long
i = 0
Dim count_i As Long
count_i = jResp.SizeOfArray("AnswerSummaries")
Do While i < count_i
jResp.I = i
IsApplicable = jResp.IntOf("AnswerSummaries[i].IsApplicable")
PillarId = jResp.StringOf("AnswerSummaries[i].PillarId")
QuestionId = jResp.StringOf("AnswerSummaries[i].QuestionId")
QuestionTitle = jResp.StringOf("AnswerSummaries[i].QuestionTitle")
Reason = jResp.StringOf("AnswerSummaries[i].Reason")
Risk = jResp.StringOf("AnswerSummaries[i].Risk")
j = 0
count_j = jResp.SizeOfArray("AnswerSummaries[i].ChoiceAnswerSummaries")
Do While j < count_j
jResp.J = j
ChoiceId = jResp.StringOf("AnswerSummaries[i].ChoiceAnswerSummaries[j].ChoiceId")
Reason = jResp.StringOf("AnswerSummaries[i].ChoiceAnswerSummaries[j].Reason")
Status = jResp.StringOf("AnswerSummaries[i].ChoiceAnswerSummaries[j].Status")
j = j + 1
Loop
j = 0
count_j = jResp.SizeOfArray("AnswerSummaries[i].Choices")
Do While j < count_j
jResp.J = j
ChoiceId = jResp.StringOf("AnswerSummaries[i].Choices[j].ChoiceId")
Description = jResp.StringOf("AnswerSummaries[i].Choices[j].Description")
DisplayText = jResp.StringOf("AnswerSummaries[i].Choices[j].HelpfulResource.DisplayText")
v_Url = jResp.StringOf("AnswerSummaries[i].Choices[j].HelpfulResource.Url")
ImprovementPlanDisplayText = jResp.StringOf("AnswerSummaries[i].Choices[j].ImprovementPlan.DisplayText")
ImprovementPlanUrl = jResp.StringOf("AnswerSummaries[i].Choices[j].ImprovementPlan.Url")
Title = jResp.StringOf("AnswerSummaries[i].Choices[j].Title")
j = j + 1
Loop
j = 0
count_j = jResp.SizeOfArray("AnswerSummaries[i].SelectedChoices")
Do While j < count_j
jResp.J = j
strVal = jResp.StringOf("AnswerSummaries[i].SelectedChoices[j]")
j = j + 1
Loop
i = i + 1
Loop
' A sample JSON response body parsed by the above code:
' {
' "AnswerSummaries": [
' {
' "ChoiceAnswerSummaries": [
' {
' "ChoiceId": "string",
' "Reason": "string",
' "Status": "string"
' }
' ],
' "Choices": [
' {
' "ChoiceId": "string",
' "Description": "string",
' "HelpfulResource": {
' "DisplayText": "string",
' "Url": "string"
' },
' "ImprovementPlan": {
' "DisplayText": "string",
' "Url": "string"
' },
' "Title": "string"
' }
' ],
' "IsApplicable": boolean,
' "PillarId": "string",
' "QuestionId": "string",
' "QuestionTitle": "string",
' "Reason": "string",
' "Risk": "string",
' "SelectedChoices": [
' "string"
' ]
' }
' ],
' "LensAlias": "string",
' "LensArn": "string",
' "MilestoneNumber": number,
' "NextToken": "string",
' "WorkloadId": "string"
' }