DescribeFirewallPolicy Foxpro Example
LOCAL loRest
LOCAL lnSuccess
LOCAL loAuthAws
LOCAL loJson
LOCAL loSbRequestBody
LOCAL loSbResponseBody
LOCAL lnRespStatusCode
LOCAL loJResp
LOCAL lcStrVal
LOCAL lcAction
LOCAL lnPriority
LOCAL lcResourceArn
LOCAL lcActionName
LOCAL j
LOCAL lnCount_j
LOCAL lcValue
LOCAL lcKey
LOCAL lcRuleOrder
LOCAL lnConsumedStatefulRuleCapacity
LOCAL lnConsumedStatelessRuleCapacity
LOCAL lcDescription
LOCAL lcKeyId
LOCAL lcV_Type
LOCAL lcFirewallPolicyArn
LOCAL lcFirewallPolicyId
LOCAL lcFirewallPolicyName
LOCAL lcFirewallPolicyStatus
LOCAL lnLastModifiedTime
LOCAL lnNumberOfAssociations
LOCAL lcUpdateToken
LOCAL i
LOCAL lnCount_i
* This example requires the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.
loRest = CreateObject('Chilkat_9_5_0.Rest')
loAuthAws = CreateObject('Chilkat_9_5_0.AuthAws')
loAuthAws.AccessKey = "AWS_ACCESS_KEY"
loAuthAws.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.)
loAuthAws.Region = "us-west-2"
loAuthAws.ServiceName = "network-firewall"
* SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
loRest.SetAuthAws(loAuthAws)
* URL: https://network-firewall.us-west-2.amazonaws.com/
* Use the same region as specified above.
lnSuccess = loRest.Connect("network-firewall.us-west-2.amazonaws.com",443,1,1)
IF (lnSuccess <> 1) THEN
? "ConnectFailReason: " + STR(loRest.ConnectFailReason)
? loRest.LastErrorText
RELEASE loRest
RELEASE loAuthAws
CANCEL
ENDIF
* 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
loJson = CreateObject('Chilkat_9_5_0.JsonObject')
loJson.UpdateString("FirewallPolicyArn","string")
loJson.UpdateString("FirewallPolicyName","string")
* The JSON request body created by the above code:
* {
* "FirewallPolicyArn": "string",
* "FirewallPolicyName": "string"
* }
loRest.AddHeader("Content-Type","application/x-amz-json-1.0")
loRest.AddHeader("X-Amz-Target","NetworkFirewall_20201112.DescribeFirewallPolicy")
loSbRequestBody = CreateObject('Chilkat_9_5_0.StringBuilder')
loJson.EmitSb(loSbRequestBody)
loSbResponseBody = CreateObject('Chilkat_9_5_0.StringBuilder')
lnSuccess = loRest.FullRequestSb("POST","/",loSbRequestBody,loSbResponseBody)
IF (lnSuccess <> 1) THEN
? loRest.LastErrorText
RELEASE loRest
RELEASE loAuthAws
RELEASE loJson
RELEASE loSbRequestBody
RELEASE loSbResponseBody
CANCEL
ENDIF
lnRespStatusCode = loRest.ResponseStatusCode
? "response status code = " + STR(lnRespStatusCode)
IF (lnRespStatusCode <> 200) THEN
? "Response Header:"
? loRest.ResponseHeader
? "Response Body:"
? loSbResponseBody.GetAsString()
RELEASE loRest
RELEASE loAuthAws
RELEASE loJson
RELEASE loSbRequestBody
RELEASE loSbResponseBody
CANCEL
ENDIF
loJResp = CreateObject('Chilkat_9_5_0.JsonObject')
loJResp.LoadSb(loSbResponseBody)
* 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
lcRuleOrder = loJResp.StringOf("FirewallPolicy.StatefulEngineOptions.RuleOrder")
lnConsumedStatefulRuleCapacity = loJResp.IntOf("FirewallPolicyResponse.ConsumedStatefulRuleCapacity")
lnConsumedStatelessRuleCapacity = loJResp.IntOf("FirewallPolicyResponse.ConsumedStatelessRuleCapacity")
lcDescription = loJResp.StringOf("FirewallPolicyResponse.Description")
lcKeyId = loJResp.StringOf("FirewallPolicyResponse.EncryptionConfiguration.KeyId")
lcV_Type = loJResp.StringOf("FirewallPolicyResponse.EncryptionConfiguration.Type")
lcFirewallPolicyArn = loJResp.StringOf("FirewallPolicyResponse.FirewallPolicyArn")
lcFirewallPolicyId = loJResp.StringOf("FirewallPolicyResponse.FirewallPolicyId")
lcFirewallPolicyName = loJResp.StringOf("FirewallPolicyResponse.FirewallPolicyName")
lcFirewallPolicyStatus = loJResp.StringOf("FirewallPolicyResponse.FirewallPolicyStatus")
lnLastModifiedTime = loJResp.IntOf("FirewallPolicyResponse.LastModifiedTime")
lnNumberOfAssociations = loJResp.IntOf("FirewallPolicyResponse.NumberOfAssociations")
lcUpdateToken = loJResp.StringOf("UpdateToken")
i = 0
lnCount_i = loJResp.SizeOfArray("FirewallPolicy.StatefulDefaultActions")
DO WHILE i < lnCount_i
loJResp.I = i
lcStrVal = loJResp.StringOf("FirewallPolicy.StatefulDefaultActions[i]")
i = i + 1
ENDDO
i = 0
lnCount_i = loJResp.SizeOfArray("FirewallPolicy.StatefulRuleGroupReferences")
DO WHILE i < lnCount_i
loJResp.I = i
lcAction = loJResp.StringOf("FirewallPolicy.StatefulRuleGroupReferences[i].Override.Action")
lnPriority = loJResp.IntOf("FirewallPolicy.StatefulRuleGroupReferences[i].Priority")
lcResourceArn = loJResp.StringOf("FirewallPolicy.StatefulRuleGroupReferences[i].ResourceArn")
i = i + 1
ENDDO
i = 0
lnCount_i = loJResp.SizeOfArray("FirewallPolicy.StatelessCustomActions")
DO WHILE i < lnCount_i
loJResp.I = i
lcActionName = loJResp.StringOf("FirewallPolicy.StatelessCustomActions[i].ActionName")
j = 0
lnCount_j = loJResp.SizeOfArray("FirewallPolicy.StatelessCustomActions[i].ActionDefinition.PublishMetricAction.Dimensions")
DO WHILE j < lnCount_j
loJResp.J = j
lcValue = loJResp.StringOf("FirewallPolicy.StatelessCustomActions[i].ActionDefinition.PublishMetricAction.Dimensions[j].Value")
j = j + 1
ENDDO
i = i + 1
ENDDO
i = 0
lnCount_i = loJResp.SizeOfArray("FirewallPolicy.StatelessDefaultActions")
DO WHILE i < lnCount_i
loJResp.I = i
lcStrVal = loJResp.StringOf("FirewallPolicy.StatelessDefaultActions[i]")
i = i + 1
ENDDO
i = 0
lnCount_i = loJResp.SizeOfArray("FirewallPolicy.StatelessFragmentDefaultActions")
DO WHILE i < lnCount_i
loJResp.I = i
lcStrVal = loJResp.StringOf("FirewallPolicy.StatelessFragmentDefaultActions[i]")
i = i + 1
ENDDO
i = 0
lnCount_i = loJResp.SizeOfArray("FirewallPolicy.StatelessRuleGroupReferences")
DO WHILE i < lnCount_i
loJResp.I = i
lnPriority = loJResp.IntOf("FirewallPolicy.StatelessRuleGroupReferences[i].Priority")
lcResourceArn = loJResp.StringOf("FirewallPolicy.StatelessRuleGroupReferences[i].ResourceArn")
i = i + 1
ENDDO
i = 0
lnCount_i = loJResp.SizeOfArray("FirewallPolicyResponse.Tags")
DO WHILE i < lnCount_i
loJResp.I = i
lcKey = loJResp.StringOf("FirewallPolicyResponse.Tags[i].Key")
lcValue = loJResp.StringOf("FirewallPolicyResponse.Tags[i].Value")
i = i + 1
ENDDO
* A sample JSON response body parsed by the above code:
* {
* "FirewallPolicy": {
* "StatefulDefaultActions": [
* "string"
* ],
* "StatefulEngineOptions": {
* "RuleOrder": "string"
* },
* "StatefulRuleGroupReferences": [
* {
* "Override": {
* "Action": "string"
* },
* "Priority": number,
* "ResourceArn": "string"
* }
* ],
* "StatelessCustomActions": [
* {
* "ActionDefinition": {
* "PublishMetricAction": {
* "Dimensions": [
* {
* "Value": "string"
* }
* ]
* }
* },
* "ActionName": "string"
* }
* ],
* "StatelessDefaultActions": [
* "string"
* ],
* "StatelessFragmentDefaultActions": [
* "string"
* ],
* "StatelessRuleGroupReferences": [
* {
* "Priority": number,
* "ResourceArn": "string"
* }
* ]
* },
* "FirewallPolicyResponse": {
* "ConsumedStatefulRuleCapacity": number,
* "ConsumedStatelessRuleCapacity": number,
* "Description": "string",
* "EncryptionConfiguration": {
* "KeyId": "string",
* "Type": "string"
* },
* "FirewallPolicyArn": "string",
* "FirewallPolicyId": "string",
* "FirewallPolicyName": "string",
* "FirewallPolicyStatus": "string",
* "LastModifiedTime": number,
* "NumberOfAssociations": number,
* "Tags": [
* {
* "Key": "string",
* "Value": "string"
* }
* ]
* },
* "UpdateToken": "string"
* }
RELEASE loRest
RELEASE loAuthAws
RELEASE loJson
RELEASE loSbRequestBody
RELEASE loSbResponseBody
RELEASE loJResp