Chilkat Online Tools

Foxpro / Core Services API / ListNetworkSecurityGroupSecurityRules

Back to Collection Items

LOCAL loHttp
LOCAL lnSuccess
LOCAL loQueryParams
LOCAL loResp
LOCAL loSbResponseBody
LOCAL loJarrResp
LOCAL lnRespStatusCode
LOCAL loJson
LOCAL lcValue
LOCAL lcProtocolValue
LOCAL lcDescriptionValue
LOCAL lcDestinationValue
LOCAL lcDestinationTypeValue
LOCAL lcIcmpOptionsValue
LOCAL lcIdValue
LOCAL lcIsStatelessValue
LOCAL lcIsValidValue
LOCAL lcSourceValue
LOCAL lcSourceTypeValue
LOCAL lcTcpOptionsValue
LOCAL lcTimeCreatedValue
LOCAL lcUdpOptionsValue
LOCAL i
LOCAL lnCount_i

* This example assumes the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.

loHttp = CreateObject('Chilkat_9_5_0.Http')

loQueryParams = CreateObject('Chilkat_9_5_0.JsonObject')
loQueryParams.UpdateString("direction","INGRESS")
loQueryParams.UpdateInt("limit",801)
loQueryParams.UpdateString("sortBy","TIMECREATED")
loQueryParams.UpdateString("sortOrder","DESC")

loHttp.SetRequestHeader("Authorization","{{signature}}")
loHttp.SetRequestHeader("Date","{{date}}")

loResp = loHttp.QuickRequestParams("GET","https://iaas.{{region}}.oraclecloud.com/20160918/networkSecurityGroups/:networkSecurityGroupId/securityRules",loQueryParams)
IF (loHttp.LastMethodSuccess = 0) THEN
    ? loHttp.LastErrorText
    RELEASE loHttp
    RELEASE loQueryParams
    CANCEL
ENDIF

loSbResponseBody = CreateObject('Chilkat_9_5_0.StringBuilder')
loResp.GetBodySb(loSbResponseBody)

loJarrResp = CreateObject('Chilkat_9_5_0.JsonArray')
loJarrResp.LoadSb(loSbResponseBody)
loJarrResp.EmitCompact = 0

? "Response Body:"
? loJarrResp.Emit()

lnRespStatusCode = loResp.StatusCode
? "Response Status Code = " + STR(lnRespStatusCode)
IF (lnRespStatusCode >= 400) THEN
    ? "Response Header:"
    ? loResp.Header
    ? "Failed."
    RELEASE loResp
    RELEASE loHttp
    RELEASE loQueryParams
    RELEASE loSbResponseBody
    RELEASE loJarrResp
    CANCEL
ENDIF

RELEASE loResp

* Sample JSON response:
* (Sample code for parsing the JSON response is shown below)

* [
*   {
*     "direction": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "protocol": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "description": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "destination": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "destinationType": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "icmpOptions": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "id": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "isStateless": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "isValid": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "source": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "sourceType": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "tcpOptions": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "timeCreated": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "udpOptions": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     }
*   },
*   {
*     "direction": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "protocol": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "description": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "destination": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "destinationType": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "icmpOptions": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "id": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "isStateless": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "isValid": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "source": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "sourceType": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "tcpOptions": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "timeCreated": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     },
*     "udpOptions": {
*       "value": "<Error: Too many levels of nesting to fake this schema>"
*     }
*   }
* ]

* Sample code for parsing the JSON response...
* Use this online tool to generate parsing code from sample JSON: Generate JSON Parsing Code

i = 0
lnCount_i = loJarrResp.Size
DO WHILE i < lnCount_i
    loJson = loJarrResp.ObjectAt(i)
    lcValue = loJson.StringOf("direction.value")
    lcProtocolValue = loJson.StringOf("protocol.value")
    lcDescriptionValue = loJson.StringOf("description.value")
    lcDestinationValue = loJson.StringOf("destination.value")
    lcDestinationTypeValue = loJson.StringOf("destinationType.value")
    lcIcmpOptionsValue = loJson.StringOf("icmpOptions.value")
    lcIdValue = loJson.StringOf("id.value")
    lcIsStatelessValue = loJson.StringOf("isStateless.value")
    lcIsValidValue = loJson.StringOf("isValid.value")
    lcSourceValue = loJson.StringOf("source.value")
    lcSourceTypeValue = loJson.StringOf("sourceType.value")
    lcTcpOptionsValue = loJson.StringOf("tcpOptions.value")
    lcTimeCreatedValue = loJson.StringOf("timeCreated.value")
    lcUdpOptionsValue = loJson.StringOf("udpOptions.value")
    RELEASE loJson
    i = i + 1
ENDDO

RELEASE loHttp
RELEASE loQueryParams
RELEASE loSbResponseBody
RELEASE loJarrResp

Curl Command

curl -G -d "direction=INGRESS"
	-d "limit=801"
	-d "sortBy=TIMECREATED"
	-d "sortOrder=DESC"
	-H "Date: {{date}}"
	-H "Authorization: {{signature}}"
https://iaas.{{region}}.oraclecloud.com/20160918/networkSecurityGroups/:networkSecurityGroupId/securityRules

Postman Collection Item JSON

{
  "name": "ListNetworkSecurityGroupSecurityRules",
  "request": {
    "method": "GET",
    "header": [
      {
        "key": "Date",
        "value": "{{date}}",
        "description": "(Required) Current Date",
        "type": "text"
      },
      {
        "key": "Authorization",
        "value": "{{signature}}",
        "description": "(Required) Signature Authentication on Authorization header",
        "type": "text"
      }
    ],
    "url": {
      "raw": "{{baseUrl}}/networkSecurityGroups/:networkSecurityGroupId/securityRules?direction=INGRESS&limit=801&sortBy=TIMECREATED&sortOrder=DESC",
      "host": [
        "{{baseUrl}}"
      ],
      "path": [
        "networkSecurityGroups",
        ":networkSecurityGroupId",
        "securityRules"
      ],
      "query": [
        {
          "key": "direction",
          "value": "INGRESS",
          "description": "Direction of the security rule. Set to `EGRESS` for rules that allow outbound IP packets,\nor `INGRESS` for rules that allow inbound IP packets.\n"
        },
        {
          "key": "limit",
          "value": "801",
          "description": "For list pagination. The maximum number of results per page, or items to return in a paginated\n\"List\" call. For important details about how pagination works, see\n[List Pagination](/iaas/Content/API/Concepts/usingapi.htm#nine).\n\nExample: `50`\n"
        },
        {
          "key": "page",
          "value": "laboris proident officia tempor",
          "description": "For list pagination. The value of the `opc-next-page` response header from the previous \"List\"\ncall. For important details about how pagination works, see\n[List Pagination](/iaas/Content/API/Concepts/usingapi.htm#nine).\n",
          "disabled": true
        },
        {
          "key": "sortBy",
          "value": "TIMECREATED",
          "description": "The field to sort by."
        },
        {
          "key": "sortOrder",
          "value": "DESC",
          "description": "The sort order to use, either ascending (`ASC`) or descending (`DESC`). The DISPLAYNAME sort order\nis case sensitive.\n"
        }
      ],
      "variable": [
        {
          "key": "networkSecurityGroupId",
          "value": "amet ut",
          "description": "(Required) The [OCID](/iaas/Content/General/Concepts/identifiers.htm) of the network security group."
        }
      ]
    },
    "description": "Lists the security rules in the specified network security group.\n"
  },
  "response": [
    {
      "name": "The list is being retrieved.",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/networkSecurityGroups/:networkSecurityGroupId/securityRules?direction=INGRESS&limit=801&page=laboris proident officia tempor&sortBy=TIMECREATED&sortOrder=DESC",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "networkSecurityGroups",
            ":networkSecurityGroupId",
            "securityRules"
          ],
          "query": [
            {
              "key": "direction",
              "value": "INGRESS"
            },
            {
              "key": "limit",
              "value": "801"
            },
            {
              "key": "page",
              "value": "laboris proident officia tempor"
            },
            {
              "key": "sortBy",
              "value": "TIMECREATED"
            },
            {
              "key": "sortOrder",
              "value": "DESC"
            }
          ],
          "variable": [
            {
              "key": "networkSecurityGroupId"
            }
          ]
        }
      },
      "status": "OK",
      "code": 200,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "opc-next-page",
          "value": "officia sed",
          "description": "For list pagination. When this header appears in the response, additional pages\nof results remain. For important details about how pagination works, see\n[List Pagination](/iaas/Content/API/Concepts/usingapi.htm#nine).\n"
        },
        {
          "key": "opc-request-id",
          "value": "officia sed",
          "description": "Unique Oracle-assigned identifier for the request. If you need to contact\nOracle about a particular request, please provide the request ID.\n"
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "[\n {\n  \"direction\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"protocol\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"description\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"destination\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"destinationType\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"icmpOptions\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"id\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"isStateless\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"isValid\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"source\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"sourceType\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"tcpOptions\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"timeCreated\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"udpOptions\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  }\n },\n {\n  \"direction\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"protocol\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"description\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"destination\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"destinationType\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"icmpOptions\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"id\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"isStateless\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"isValid\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"source\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"sourceType\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"tcpOptions\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"timeCreated\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"udpOptions\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  }\n }\n]"
    },
    {
      "name": "Bad Request",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/networkSecurityGroups/:networkSecurityGroupId/securityRules?direction=INGRESS&limit=801&page=laboris proident officia tempor&sortBy=TIMECREATED&sortOrder=DESC",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "networkSecurityGroups",
            ":networkSecurityGroupId",
            "securityRules"
          ],
          "query": [
            {
              "key": "direction",
              "value": "INGRESS"
            },
            {
              "key": "limit",
              "value": "801"
            },
            {
              "key": "page",
              "value": "laboris proident officia tempor"
            },
            {
              "key": "sortBy",
              "value": "TIMECREATED"
            },
            {
              "key": "sortOrder",
              "value": "DESC"
            }
          ],
          "variable": [
            {
              "key": "networkSecurityGroupId"
            }
          ]
        }
      },
      "status": "Bad Request",
      "code": 400,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "opc-request-id",
          "value": "officia sed",
          "description": "Unique Oracle-assigned identifier for the request. If you need to contact\nOracle about a particular request, please provide the request ID.\n"
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n \"code\": \"et exercitation Excepteur\",\n \"message\": \"irure sit\"\n}"
    },
    {
      "name": "Unauthorized",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/networkSecurityGroups/:networkSecurityGroupId/securityRules?direction=INGRESS&limit=801&page=laboris proident officia tempor&sortBy=TIMECREATED&sortOrder=DESC",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "networkSecurityGroups",
            ":networkSecurityGroupId",
            "securityRules"
          ],
          "query": [
            {
              "key": "direction",
              "value": "INGRESS"
            },
            {
              "key": "limit",
              "value": "801"
            },
            {
              "key": "page",
              "value": "laboris proident officia tempor"
            },
            {
              "key": "sortBy",
              "value": "TIMECREATED"
            },
            {
              "key": "sortOrder",
              "value": "DESC"
            }
          ],
          "variable": [
            {
              "key": "networkSecurityGroupId"
            }
          ]
        }
      },
      "status": "Unauthorized",
      "code": 401,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "opc-request-id",
          "value": "officia sed",
          "description": "Unique Oracle-assigned identifier for the request. If you need to contact\nOracle about a particular request, please provide the request ID.\n"
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n \"code\": \"et exercitation Excepteur\",\n \"message\": \"irure sit\"\n}"
    },
    {
      "name": "Not Found",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/networkSecurityGroups/:networkSecurityGroupId/securityRules?direction=INGRESS&limit=801&page=laboris proident officia tempor&sortBy=TIMECREATED&sortOrder=DESC",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "networkSecurityGroups",
            ":networkSecurityGroupId",
            "securityRules"
          ],
          "query": [
            {
              "key": "direction",
              "value": "INGRESS"
            },
            {
              "key": "limit",
              "value": "801"
            },
            {
              "key": "page",
              "value": "laboris proident officia tempor"
            },
            {
              "key": "sortBy",
              "value": "TIMECREATED"
            },
            {
              "key": "sortOrder",
              "value": "DESC"
            }
          ],
          "variable": [
            {
              "key": "networkSecurityGroupId"
            }
          ]
        }
      },
      "status": "Not Found",
      "code": 404,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "opc-request-id",
          "value": "officia sed",
          "description": "Unique Oracle-assigned identifier for the request. If you need to contact\nOracle about a particular request, please provide the request ID.\n"
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n \"code\": \"et exercitation Excepteur\",\n \"message\": \"irure sit\"\n}"
    },
    {
      "name": "Internal Server Error",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/networkSecurityGroups/:networkSecurityGroupId/securityRules?direction=INGRESS&limit=801&page=laboris proident officia tempor&sortBy=TIMECREATED&sortOrder=DESC",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "networkSecurityGroups",
            ":networkSecurityGroupId",
            "securityRules"
          ],
          "query": [
            {
              "key": "direction",
              "value": "INGRESS"
            },
            {
              "key": "limit",
              "value": "801"
            },
            {
              "key": "page",
              "value": "laboris proident officia tempor"
            },
            {
              "key": "sortBy",
              "value": "TIMECREATED"
            },
            {
              "key": "sortOrder",
              "value": "DESC"
            }
          ],
          "variable": [
            {
              "key": "networkSecurityGroupId"
            }
          ]
        }
      },
      "status": "Internal Server Error",
      "code": 500,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "opc-request-id",
          "value": "officia sed",
          "description": "Unique Oracle-assigned identifier for the request. If you need to contact\nOracle about a particular request, please provide the request ID.\n"
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n \"code\": \"et exercitation Excepteur\",\n \"message\": \"irure sit\"\n}"
    },
    {
      "name": "An error has occurred.",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/networkSecurityGroups/:networkSecurityGroupId/securityRules?direction=INGRESS&limit=801&page=laboris proident officia tempor&sortBy=TIMECREATED&sortOrder=DESC",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "networkSecurityGroups",
            ":networkSecurityGroupId",
            "securityRules"
          ],
          "query": [
            {
              "key": "direction",
              "value": "INGRESS"
            },
            {
              "key": "limit",
              "value": "801"
            },
            {
              "key": "page",
              "value": "laboris proident officia tempor"
            },
            {
              "key": "sortBy",
              "value": "TIMECREATED"
            },
            {
              "key": "sortOrder",
              "value": "DESC"
            }
          ],
          "variable": [
            {
              "key": "networkSecurityGroupId"
            }
          ]
        }
      },
      "status": "Internal Server Error",
      "code": 500,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "opc-request-id",
          "value": "officia sed",
          "description": "Unique Oracle-assigned identifier for the request. If you need to contact\nOracle about a particular request, please provide the request ID.\n"
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n \"code\": \"et exercitation Excepteur\",\n \"message\": \"irure sit\"\n}"
    }
  ]
}