ExportThemes VB6 Example
ᔓ䀈➟n style="color: rgb(108,122,133)">' 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 = "amplifyuibuilder"
' SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
success = rest.SetAuthAws(authAws)
' URL: https://amplifyuibuilder.us-west-2.amazonaws.com/
' Use the same region as specified above.
success = rest.Connect("amplifyuibuilder.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","ExportThemes")
Dim sbResponseBody As New ChilkatStringBuilder
success = rest.FullRequestNoBodySb("GET","/export/app/{appId}/environment/{environmentName}/themes",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 appId As String
Dim createdAt As Long
Dim environmentName As String
Dim id As String
Dim modifiedAt As Long
Dim name As String
Dim v_String As String
Dim j As Long
Dim count_j As Long
Dim key As String
Dim Value As String
Dim k As Long
Dim count_k As Long
Dim strVal As String
Dim valueValue As String
Dim nextToken As String
nextToken = jResp.StringOf("nextToken")
Dim i As Long
i = 0
Dim count_i As Long
count_i = jResp.SizeOfArray("entities")
Do While i < count_i
jResp.I = i
appId = jResp.StringOf("entities[i].appId")
createdAt = jResp.IntOf("entities[i].createdAt")
environmentName = jResp.StringOf("entities[i].environmentName")
id = jResp.StringOf("entities[i].id")
modifiedAt = jResp.IntOf("entities[i].modifiedAt")
name = jResp.StringOf("entities[i].name")
v_String = jResp.StringOf("entities[i].tags.string")
j = 0
count_j = jResp.SizeOfArray("entities[i].overrides")
Do While j < count_j
jResp.J = j
key = jResp.StringOf("entities[i].overrides[j].key")
Value = jResp.StringOf("entities[i].overrides[j].value.value")
k = 0
count_k = jResp.SizeOfArray("entities[i].overrides[j].value.children")
Do While k < count_k
jResp.K = k
strVal = jResp.StringOf("entities[i].overrides[j].value.children[k]")
k = k + 1
Loop
j = j + 1
Loop
j = 0
count_j = jResp.SizeOfArray("entities[i].values")
Do While j < count_j
jResp.J = j
key = jResp.StringOf("entities[i].values[j].key")
valueValue = jResp.StringOf("entities[i].values[j].value.value")
k = 0
count_k = jResp.SizeOfArray("entities[i].values[j].value.children")
Do While k < count_k
jResp.K = k
strVal = jResp.StringOf("entities[i].values[j].value.children[k]")
k = k + 1
Loop
j = j + 1
Loop
i = i + 1
Loop
' A sample JSON response body parsed by the above code:
' {
' "entities": [
' {
' "appId": "string",
' "createdAt": number,
' "environmentName": "string",
' "id": "string",
' "modifiedAt": number,
' "name": "string",
' "overrides": [
' {
' "key": "string",
' "value": {
' "children": [
' "ThemeValues"
' ],
' "value": "string"
' }
' }
' ],
' "tags": {
' "string": "string"
' },
' "values": [
' {
' "key": "string",
' "value": {
' "children": [
' "ThemeValues"
' ],
' "value": "string"
' }
' }
' ]
' }
' ],
' "nextToken": "string"
' }