Chilkat Online Tools

CreateMeetingWithAttendees VB.NET Example

Amazon Chime

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

Dim rest As New Chilkat.Rest
Dim success As Boolean

Dim authAws As New Chilkat.AuthAws
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 = "chime"
' SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
rest.SetAuthAws(authAws)

' URL: https://chime.us-west-2.amazonaws.com/
' Use the same region as specified above.
success = rest.Connect("chime.us-west-2.amazonaws.com",443,True,True)
If (success <> True) Then
    Debug.WriteLine("ConnectFailReason: " & rest.ConnectFailReason)
    Debug.WriteLine(rest.LastErrorText)
    Exit Sub
End If


' 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

Dim json As New Chilkat.JsonObject
json.UpdateString("Attendees[0].ExternalUserId","string")
json.UpdateString("Attendees[0].Tags[0].Key","string")
json.UpdateString("Attendees[0].Tags[0].Value","string")
json.UpdateString("ClientRequestToken","string")
json.UpdateString("ExternalMeetingId","string")
json.UpdateString("MediaRegion","string")
json.UpdateString("MeetingHostId","string")
json.UpdateString("NotificationsConfiguration.SnsTopicArn","string")
json.UpdateString("NotificationsConfiguration.SqsQueueArn","string")
json.UpdateString("Tags[0].Key","string")
json.UpdateString("Tags[0].Value","string")

' The JSON request body created by the above code:

' {
'   "Attendees": [
'     {
'       "ExternalUserId": "string",
'       "Tags": [
'         {
'           "Key": "string",
'           "Value": "string"
'         }
'       ]
'     }
'   ],
'   "ClientRequestToken": "string",
'   "ExternalMeetingId": "string",
'   "MediaRegion": "string",
'   "MeetingHostId": "string",
'   "NotificationsConfiguration": {
'     "SnsTopicArn": "string",
'     "SqsQueueArn": "string"
'   },
'   "Tags": [
'     {
'       "Key": "string",
'       "Value": "string"
'     }
'   ]
' }

rest.AddHeader("Content-Type","application/x-amz-json-1.1")
rest.AddHeader("X-Amz-Target","CreateMeetingWithAttendees")

Dim sbRequestBody As New Chilkat.StringBuilder
json.EmitSb(sbRequestBody)
Dim sbResponseBody As New Chilkat.StringBuilder
success = rest.FullRequestSb("POST","/meetings?operation=create-attendees",sbRequestBody,sbResponseBody)
If (success <> True) Then
    Debug.WriteLine(rest.LastErrorText)
    Exit Sub
End If

Dim respStatusCode As Integer = rest.ResponseStatusCode
Debug.WriteLine("response status code = " & respStatusCode)
If (respStatusCode <> 200) Then
    Debug.WriteLine("Response Header:")
    Debug.WriteLine(rest.ResponseHeader)
    Debug.WriteLine("Response Body:")
    Debug.WriteLine(sbResponseBody.GetAsString())
    Exit Sub
End If


Dim jResp As New Chilkat.JsonObject
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 AttendeeId As String
Dim ExternalUserId As String
Dim JoinToken As String
Dim ErrorCode As String
Dim ErrorMessage As String

Dim ExternalMeetingId As String = jResp.StringOf("Meeting.ExternalMeetingId")
Dim AudioFallbackUrl As String = jResp.StringOf("Meeting.MediaPlacement.AudioFallbackUrl")
Dim AudioHostUrl As String = jResp.StringOf("Meeting.MediaPlacement.AudioHostUrl")
Dim EventIngestionUrl As String = jResp.StringOf("Meeting.MediaPlacement.EventIngestionUrl")
Dim ScreenDataUrl As String = jResp.StringOf("Meeting.MediaPlacement.ScreenDataUrl")
Dim ScreenSharingUrl As String = jResp.StringOf("Meeting.MediaPlacement.ScreenSharingUrl")
Dim ScreenViewingUrl As String = jResp.StringOf("Meeting.MediaPlacement.ScreenViewingUrl")
Dim SignalingUrl As String = jResp.StringOf("Meeting.MediaPlacement.SignalingUrl")
Dim TurnControlUrl As String = jResp.StringOf("Meeting.MediaPlacement.TurnControlUrl")
Dim MediaRegion As String = jResp.StringOf("Meeting.MediaRegion")
Dim MeetingId As String = jResp.StringOf("Meeting.MeetingId")
Dim i As Integer = 0
Dim count_i As Integer = jResp.SizeOfArray("Attendees")
While i < count_i
    jResp.I = i
    AttendeeId = jResp.StringOf("Attendees[i].AttendeeId")
    ExternalUserId = jResp.StringOf("Attendees[i].ExternalUserId")
    JoinToken = jResp.StringOf("Attendees[i].JoinToken")
    i = i + 1
End While
i = 0
count_i = jResp.SizeOfArray("Errors")
While i < count_i
    jResp.I = i
    ErrorCode = jResp.StringOf("Errors[i].ErrorCode")
    ErrorMessage = jResp.StringOf("Errors[i].ErrorMessage")
    ExternalUserId = jResp.StringOf("Errors[i].ExternalUserId")
    i = i + 1
End While


' A sample JSON response body parsed by the above code:

' {
'   "Attendees": [
'     {
'       "AttendeeId": "string",
'       "ExternalUserId": "string",
'       "JoinToken": "string"
'     }
'   ],
'   "Errors": [
'     {
'       "ErrorCode": "string",
'       "ErrorMessage": "string",
'       "ExternalUserId": "string"
'     }
'   ],
'   "Meeting": {
'     "ExternalMeetingId": "string",
'     "MediaPlacement": {
'       "AudioFallbackUrl": "string",
'       "AudioHostUrl": "string",
'       "EventIngestionUrl": "string",
'       "ScreenDataUrl": "string",
'       "ScreenSharingUrl": "string",
'       "ScreenViewingUrl": "string",
'       "SignalingUrl": "string",
'       "TurnControlUrl": "string"
'     },
'     "MediaRegion": "string",
'     "MeetingId": "string"
'   }
' }