Chilkat Online Tools

DataFlex / Zoom API / Get a meeting survey

Back to Collection Items

Use ChilkatAx-win32.pkg

Procedure Test
    Handle hoHttp
    Boolean iSuccess
    Variant vSbResponseBody
    Handle hoSbResponseBody
    Handle hoJResp
    Integer iRespStatusCode
    String sName
    String sV_type
    Boolean iShow_as_dropdown
    Boolean iAnswer_required
    Integer iRating_min_value
    Integer iRating_max_value
    String sRating_min_label
    String sRating_max_label
    Integer iAnswer_min_character
    Integer iAnswer_max_character
    Integer j
    Integer iCount_j
    String sStrVal
    Boolean iAnonymous
    Boolean iShow_in_the_browser
    Integer i
    Integer iCount_i
    String sTemp1

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

    // Adds the "Authorization: Bearer <access_token>" header.
    Set ComAuthToken Of hoHttp To "<access_token>"

    Get Create (RefClass(cComChilkatStringBuilder)) To hoSbResponseBody
    If (Not(IsComObjectCreated(hoSbResponseBody))) Begin
        Send CreateComObject of hoSbResponseBody
    End
    Get pvComObject of hoSbResponseBody to vSbResponseBody
    Get ComQuickGetSb Of hoHttp "https://api.zoom.us/v2/meetings/:meetingId/survey" vSbResponseBody To iSuccess
    If (iSuccess = False) Begin
        Get ComLastErrorText Of hoHttp To sTemp1
        Showln sTemp1
        Procedure_Return
    End

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

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

    Get ComLastStatus Of hoHttp To iRespStatusCode
    Showln "Response Status Code = " iRespStatusCode
    If (iRespStatusCode >= 400) Begin
        Showln "Response Header:"
        Get ComLastHeader Of hoHttp To sTemp1
        Showln sTemp1
        Showln "Failed."
        Procedure_Return
    End

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

    // {
    //   "custom_survey": {
    //     "anonymous": true,
    //     "questions": [
    //       {
    //         "name": "Single Choice",
    //         "type": "single",
    //         "show_as_dropdown": false,
    //         "answer_required": false,
    //         "answers": [
    //           "option1",
    //           "option2",
    //           "option3"
    //         ]
    //       },
    //       {
    //         "name": "Multiple Choice",
    //         "type": "multiple",
    //         "answer_required": false,
    //         "answers": [
    //           "option1",
    //           "option2",
    //           "option3"
    //         ]
    //       },
    //       {
    //         "name": "Rating Scale",
    //         "type": "rating_scale",
    //         "answer_required": false,
    //         "rating_min_value": 0,
    //         "rating_max_value": 4,
    //         "rating_min_label": "Not likely",
    //         "rating_max_label": "Extremely Likely"
    //       },
    //       {
    //         "name": "Long Answer",
    //         "type": "long_answer",
    //         "answer_required": false,
    //         "answer_min_character": 1,
    //         "answer_max_character": 200
    //       }
    //     ]
    //   },
    //   "show_in_the_browser": true
    // }

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

    Get ComBoolOf Of hoJResp "custom_survey.anonymous" To iAnonymous
    Get ComBoolOf Of hoJResp "show_in_the_browser" To iShow_in_the_browser
    Move 0 To i
    Get ComSizeOfArray Of hoJResp "custom_survey.questions" To iCount_i
    While (i < iCount_i)
        Set ComI Of hoJResp To i
        Get ComStringOf Of hoJResp "custom_survey.questions[i].name" To sName
        Get ComStringOf Of hoJResp "custom_survey.questions[i].type" To sV_type
        Get ComBoolOf Of hoJResp "custom_survey.questions[i].show_as_dropdown" To iShow_as_dropdown
        Get ComBoolOf Of hoJResp "custom_survey.questions[i].answer_required" To iAnswer_required
        Get ComIntOf Of hoJResp "custom_survey.questions[i].rating_min_value" To iRating_min_value
        Get ComIntOf Of hoJResp "custom_survey.questions[i].rating_max_value" To iRating_max_value
        Get ComStringOf Of hoJResp "custom_survey.questions[i].rating_min_label" To sRating_min_label
        Get ComStringOf Of hoJResp "custom_survey.questions[i].rating_max_label" To sRating_max_label
        Get ComIntOf Of hoJResp "custom_survey.questions[i].answer_min_character" To iAnswer_min_character
        Get ComIntOf Of hoJResp "custom_survey.questions[i].answer_max_character" To iAnswer_max_character
        Move 0 To j
        Get ComSizeOfArray Of hoJResp "custom_survey.questions[i].answers" To iCount_j
        While (j < iCount_j)
            Set ComJ Of hoJResp To j
            Get ComStringOf Of hoJResp "custom_survey.questions[i].answers[j]" To sStrVal
            Move (j + 1) To j
        Loop

        Move (i + 1) To i
    Loop



End_Procedure

Curl Command

curl -X GET
	-H "Authorization: Bearer <access_token>"
https://api.zoom.us/v2/meetings/:meetingId/survey

Postman Collection Item JSON

{
  "name": "Get a meeting survey",
  "request": {
    "auth": {
      "type": "oauth2"
    },
    "method": "GET",
    "header": [
    ],
    "url": {
      "raw": "{{baseUrl}}/meetings/:meetingId/survey",
      "host": [
        "{{baseUrl}}"
      ],
      "path": [
        "meetings",
        ":meetingId",
        "survey"
      ],
      "variable": [
        {
          "key": "meetingId",
          "value": "68423085",
          "description": "(Required) The meeting's ID. \n\n When storing this value in your database, you must store it as a **long** format integer and **not** an integer. Meeting IDs can exceed 10 digits."
        }
      ]
    },
    "description": "Use this API to return information about a [meeting survey](https://support.zoom.us/hc/en-us/articles/4404969060621-Post-meeting-survey-and-reporting). \n\n **Scopes:** `meeting:read`, `meeting:read:admin` <br> **[Rate Limit Label](https://marketplace.zoom.us/docs/api-reference/rate-limits#rate-limits):** `Light` \n\n **Prerequisites:** \n* The host must be a **Pro** user type. \n* The [**Meeting Survey**](https://support.zoom.us/hc/en-us/articles/4404939095053-Enabling-meeting-surveys) feature enabled in the host's account. \n* The meeting must be a scheduled meeting. Instant meetings do not have survey features enabled."
  },
  "response": [
    {
      "name": "**HTTP Status Code:** `200` <br>\n Meeting survey object returned.",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "description": "Added as a part of security scheme: oauth2",
            "key": "Authorization",
            "value": "<token>"
          }
        ],
        "url": {
          "raw": "{{baseUrl}}/meetings/:meetingId/survey",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "meetings",
            ":meetingId",
            "survey"
          ],
          "variable": [
            {
              "key": "meetingId",
              "value": "68423085",
              "description": "(Required) The meeting's ID. \n\n When storing this value in your database, you must store it as a **long** format integer and **not** an integer. Meeting IDs can exceed 10 digits."
            }
          ]
        }
      },
      "status": "OK",
      "code": 200,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n \"custom_survey\": {\n  \"anonymous\": true,\n  \"questions\": [\n   {\n    \"name\": \"Single Choice\",\n    \"type\": \"single\",\n    \"show_as_dropdown\": false,\n    \"answer_required\": false,\n    \"answers\": [\n     \"option1\",\n     \"option2\",\n     \"option3\"\n    ]\n   },\n   {\n    \"name\": \"Multiple Choice\",\n    \"type\": \"multiple\",\n    \"answer_required\": false,\n    \"answers\": [\n     \"option1\",\n     \"option2\",\n     \"option3\"\n    ]\n   },\n   {\n    \"name\": \"Rating Scale\",\n    \"type\": \"rating_scale\",\n    \"answer_required\": false,\n    \"rating_min_value\": 0,\n    \"rating_max_value\": 4,\n    \"rating_min_label\": \"Not likely\",\n    \"rating_max_label\": \"Extremely Likely\"\n   },\n   {\n    \"name\": \"Long Answer\",\n    \"type\": \"long_answer\",\n    \"answer_required\": false,\n    \"answer_min_character\": 1,\n    \"answer_max_character\": 200\n   }\n  ]\n },\n \"show_in_the_browser\": true\n}"
    },
    {
      "name": "**HTTP Status Code:** `400` <br> Bad Request \n\n **Error Code:** `300` <br>\n Invalid meeting ID. \n\n **Error Code:** `3000` <br>\n * Cannot access Webinar information. <br>\n * Meeting survey disabled. To enable this feature, enable the \"Meeting Survey\" setti",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "description": "Added as a part of security scheme: oauth2",
            "key": "Authorization",
            "value": "<token>"
          }
        ],
        "url": {
          "raw": "{{baseUrl}}/meetings/:meetingId/survey",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "meetings",
            ":meetingId",
            "survey"
          ],
          "variable": [
            {
              "key": "meetingId",
              "value": "68423085",
              "description": "(Required) The meeting's ID. \n\n When storing this value in your database, you must store it as a **long** format integer and **not** an integer. Meeting IDs can exceed 10 digits."
            }
          ]
        }
      },
      "status": "Bad Request",
      "code": 400,
      "_postman_previewlanguage": "text",
      "header": [
        {
          "key": "Content-Type",
          "value": "text/plain"
        }
      ],
      "cookie": [
      ],
      "body": ""
    },
    {
      "name": "**HTTP Status Code:** `404` <br> Not Found \n\n **Error Code:** `300` <br>\n Meeting ID does not exist. \n\n **Error Code:** `3001` <br>\n Meeting does not exist: {meetingId}.",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "description": "Added as a part of security scheme: oauth2",
            "key": "Authorization",
            "value": "<token>"
          }
        ],
        "url": {
          "raw": "{{baseUrl}}/meetings/:meetingId/survey",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "meetings",
            ":meetingId",
            "survey"
          ],
          "variable": [
            {
              "key": "meetingId",
              "value": "68423085",
              "description": "(Required) The meeting's ID. \n\n When storing this value in your database, you must store it as a **long** format integer and **not** an integer. Meeting IDs can exceed 10 digits."
            }
          ]
        }
      },
      "status": "Not Found",
      "code": 404,
      "_postman_previewlanguage": "text",
      "header": [
        {
          "key": "Content-Type",
          "value": "text/plain"
        }
      ],
      "cookie": [
      ],
      "body": ""
    }
  ]
}