Chilkat Online Tools

DataFlex / Core Services API / ListNetworkSecurityGroupSecurityRules

Back to Collection Items

Use ChilkatAx-win32.pkg

Procedure Test
    Handle hoHttp
    Boolean iSuccess
    Variant vQueryParams
    Handle hoQueryParams
    Variant vResp
    Handle hoResp
    Variant vSbResponseBody
    Handle hoSbResponseBody
    Handle hoJarrResp
    Integer iRespStatusCode
    Variant vJson
    Handle hoJson
    String sValue
    String sProtocolValue
    String sDescriptionValue
    String sDestinationValue
    String sDestinationTypeValue
    String sIcmpOptionsValue
    String sIdValue
    String sIsStatelessValue
    String sIsValidValue
    String sSourceValue
    String sSourceTypeValue
    String sTcpOptionsValue
    String sTimeCreatedValue
    String sUdpOptionsValue
    Integer i
    Integer iCount_i
    String sTemp1
    Boolean bTemp1

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

    Get Create (RefClass(cComChilkatHttp)) To hoHttp
    If (Not(IsComObjectCreated(hoHttp))) Begin
        Send CreateComObject of hoHttp
    End

    Get Create (RefClass(cComChilkatJsonObject)) To hoQueryParams
    If (Not(IsComObjectCreated(hoQueryParams))) Begin
        Send CreateComObject of hoQueryParams
    End
    Get ComUpdateString Of hoQueryParams "direction" "INGRESS" To iSuccess
    Get ComUpdateInt Of hoQueryParams "limit" 801 To iSuccess
    Get ComUpdateString Of hoQueryParams "sortBy" "TIMECREATED" To iSuccess
    Get ComUpdateString Of hoQueryParams "sortOrder" "DESC" To iSuccess

    Send ComSetRequestHeader To hoHttp "Authorization" "{{signature}}"
    Send ComSetRequestHeader To hoHttp "Date" "{{date}}"

    Get pvComObject of hoQueryParams to vQueryParams
    Get ComQuickRequestParams Of hoHttp "GET" "https://iaas.{{region}}.oraclecloud.com/20160918/networkSecurityGroups/:networkSecurityGroupId/securityRules" vQueryParams To vResp
    If (IsComObject(vResp)) Begin
        Get Create (RefClass(cComChilkatHttpResponse)) To hoResp
        Set pvComObject Of hoResp To vResp
    End
    Get ComLastMethodSuccess Of hoHttp To bTemp1
    If (bTemp1 = False) Begin
        Get ComLastErrorText Of hoHttp To sTemp1
        Showln sTemp1
        Procedure_Return
    End

    Get Create (RefClass(cComChilkatStringBuilder)) To hoSbResponseBody
    If (Not(IsComObjectCreated(hoSbResponseBody))) Begin
        Send CreateComObject of hoSbResponseBody
    End
    Get pvComObject of hoSbResponseBody to vSbResponseBody
    Get ComGetBodySb Of hoResp vSbResponseBody To iSuccess

    Get Create (RefClass(cComChilkatJsonArray)) To hoJarrResp
    If (Not(IsComObjectCreated(hoJarrResp))) Begin
        Send CreateComObject of hoJarrResp
    End
    Get pvComObject of hoSbResponseBody to vSbResponseBody
    Get ComLoadSb Of hoJarrResp vSbResponseBody To iSuccess
    Set ComEmitCompact Of hoJarrResp To False

    Showln "Response Body:"
    Get ComEmit Of hoJarrResp To sTemp1
    Showln sTemp1

    Get ComStatusCode Of hoResp To iRespStatusCode
    Showln "Response Status Code = " iRespStatusCode
    If (iRespStatusCode >= 400) Begin
        Showln "Response Header:"
        Get ComHeader Of hoResp To sTemp1
        Showln sTemp1
        Showln "Failed."
        Send Destroy of hoResp
        Procedure_Return
    End

    Send Destroy of hoResp

    // 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

    Move 0 To i
    Get ComSize Of hoJarrResp To iCount_i
    While (i < iCount_i)
        Get ComObjectAt Of hoJarrResp i To vJson
        If (IsComObject(vJson)) Begin
            Get Create (RefClass(cComChilkatJsonObject)) To hoJson
            Set pvComObject Of hoJson To vJson
        End
        Get ComStringOf Of hoJson "direction.value" To sValue
        Get ComStringOf Of hoJson "protocol.value" To sProtocolValue
        Get ComStringOf Of hoJson "description.value" To sDescriptionValue
        Get ComStringOf Of hoJson "destination.value" To sDestinationValue
        Get ComStringOf Of hoJson "destinationType.value" To sDestinationTypeValue
        Get ComStringOf Of hoJson "icmpOptions.value" To sIcmpOptionsValue
        Get ComStringOf Of hoJson "id.value" To sIdValue
        Get ComStringOf Of hoJson "isStateless.value" To sIsStatelessValue
        Get ComStringOf Of hoJson "isValid.value" To sIsValidValue
        Get ComStringOf Of hoJson "source.value" To sSourceValue
        Get ComStringOf Of hoJson "sourceType.value" To sSourceTypeValue
        Get ComStringOf Of hoJson "tcpOptions.value" To sTcpOptionsValue
        Get ComStringOf Of hoJson "timeCreated.value" To sTimeCreatedValue
        Get ComStringOf Of hoJson "udpOptions.value" To sUdpOptionsValue
        Send Destroy of hoJson
        Move (i + 1) To i
    Loop



End_Procedure

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}"
    }
  ]
}