Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(DataFlex) MS Teamwork: Update an Online MeetingSee more Microsoft Teams ExamplesDemonstrates how to update a Microsoft Teamwork Online Meeting Note:If using Application access (i.e. client credentials) which is what this example is doing, then you'll need to "Configure application access to online meetings or virtual events" See https://learn.microsoft.com/en-us/graph/cloud-communication-online-meeting-application-access-policy#configure-application-access-policy For example, here's our Powershell session to setup the policy. Windows PowerShell Copyright (C) Microsoft Corporation. All rights reserved. Try the new cross-platform PowerShell https://aka.ms/pscore6 PS C:\WINDOWS\system32> Install-Module -Name PowerShellGet -Force -AllowClobber PS C:\WINDOWS\system32> Install-Module -Name MicrosoftTeams -Force -AllowClobber PS C:\WINDOWS\system32> Connect-MicrosoftTeams Account Environment Tenant TenantId ------- ----------- ------ -------- admin@chilkat365.com AzureCloud 112d7ed6-71bf-4eba-a866-738364321bfc 112d7ed6-71bf-4eba-a866-738364321bfc PS C:\WINDOWS\system32> New-CsApplicationAccessPolicy -Identity Test-Teams-policy -AppIds "e1cd2318-298b-4916-bfd6-78cae9938835" -Description "Want App to be able to work with Teams for a User" Identity : Tag:Test-Teams-policy AppIds : {e1cd2318-298b-4916-bfd6-78cae9938835} Description : Want App to be able to work with Teams for a User PS C:\WINDOWS\system32> Grant-CsApplicationAccessPolicy -PolicyName Test-Teams-policy -Identity "4ee732c3-322e-4a6b-b729-2fd1eb5c6004" PS C:\WINDOWS\system32> Note: This example uses the new "Integrated OAuth2 Client Credentials" feature introduced in Chilkat v9.5.0.96. For more information, see https://learn.microsoft.com/en-us/graph/api/onlinemeeting-update?view=graph-rest-1.0&tabs=http
Use ChilkatAx-win32.pkg Procedure Test Boolean iSuccess Handle hoHttp Handle hoJsonOAuthCC Handle hoJson Variant vSbRequestBody Handle hoSbRequestBody String sUserId String sMeetingId Handle hoSbUrl Integer iNumReplaced Variant vResp Handle hoResp Handle hoJsonResp Integer iStatusCode String sTemp1 Boolean bTemp1 // This requires 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 // Provide the information needed for Chilkat to automatically fetch the OAuth2.0 // access token as needed. // This is the new "Integrated OAuth2 Client Credentials" feature introduced in Chilkat v9.5.0.96. Get Create (RefClass(cComChilkatJsonObject)) To hoJsonOAuthCC If (Not(IsComObjectCreated(hoJsonOAuthCC))) Begin Send CreateComObject of hoJsonOAuthCC End // -------------------------------------------------------------------------------------------------------- // You'll need to have registered an app in Azure beforehand. // // Note: Creating an online meeting requires the following Application permission: OnlineMeetings.ReadWrite.All // // See How to Create an Azure App Registration for OAuth 2.0 Client Credentials // -------------------------------------------------------------------------------------------------------- // Use the values from your App Registration in Azure. Get ComUpdateString Of hoJsonOAuthCC "client_id" "e1cd2318-xxxx-4916-bfd6-xxxxxxxxxxxx" To iSuccess Get ComUpdateString Of hoJsonOAuthCC "client_secret" "K.d8Q~RoJxxxxvCj_u_xxxxxxxxxxxxxxxxxxxxx" To iSuccess // You'll always use this scope for client credentials, because the allowed actions // are determined by the App Permissions defined when you registered the app in Azure. Get ComUpdateString Of hoJsonOAuthCC "scope" "https://graph.microsoft.com/.default" To iSuccess // The token endpoint includes your tenant ID. Use your tenant ID (not the tenant ID shown here). Get ComUpdateString Of hoJsonOAuthCC "token_endpoint" "https://login.microsoftonline.com/112d7ed6-71bf-4eba-a866-738364321bfc/oauth2/v2.0/token" To iSuccess // Provide the OAuth2 information. Chilkat will use this information to automatically fetch the OAuth2 access token as needed, Get ComEmit Of hoJsonOAuthCC To sTemp1 Set ComAuthToken Of hoHttp To sTemp1 // ------------------------------------------------------------------------------------------- // The following JSON is sent in the request body. // { // "startDateTime": "2023-12-14T14:33:30-07:00", // "endDateTime": "2023-12-14T15:03:30-07:00", // "subject": "Patch Meeting Subject" // } Get Create (RefClass(cComChilkatJsonObject)) To hoJson If (Not(IsComObjectCreated(hoJson))) Begin Send CreateComObject of hoJson End Get ComUpdateString Of hoJson "startDateTime" "2023-12-14T14:33:30-07:00" To iSuccess Get ComUpdateString Of hoJson "endDateTime" "2023-12-14T15:03:30-07:00" To iSuccess Get ComUpdateString Of hoJson "subject" "Patch Meeting Subject" To iSuccess Get Create (RefClass(cComChilkatStringBuilder)) To hoSbRequestBody If (Not(IsComObjectCreated(hoSbRequestBody))) Begin Send CreateComObject of hoSbRequestBody End Get pvComObject of hoSbRequestBody to vSbRequestBody Get ComEmitSb Of hoJson vSbRequestBody To iSuccess // To update an online meeting, send a PATCH request like this: // // PATCH https://graph.microsoft.com/v1.0/users/{userId}/onlineMeetings/{meetingId} // Content-Type: application/json // // { // "startDateTime": "2020-09-09T14:33:30.8546353-07:00", // "endDateTime": "2020-09-09T15:03:30.8566356-07:00", // "subject": "Patch Meeting Subject" // } Move "4ee732c3-322e-4a6b-b729-2fd1eb5c6004" To sUserId Move "MSo0ZWU3MzJjMy0zMjJlLTRhNmItYjcyOS0yZmQxZWI1YzYwMDQqMCoqMTk6bWVldGluZ19OemMwT0RGa1pESXRNV1ZoTkMwME9UQXpMV0psWXpJdFkyRXdNR0kzTVdNME5qTmpAdGhyZWFkLnYy" To sMeetingId Get Create (RefClass(cComChilkatStringBuilder)) To hoSbUrl If (Not(IsComObjectCreated(hoSbUrl))) Begin Send CreateComObject of hoSbUrl End Get ComAppend Of hoSbUrl "https://graph.microsoft.com/v1.0/users/{userId}/onlineMeetings/{meetingId}" To iSuccess Get ComReplace Of hoSbUrl "{userId}" sUserId To iNumReplaced Get ComReplace Of hoSbUrl "{meetingId}" sMeetingId To iNumReplaced Get ComGetAsString Of hoSbUrl To sTemp1 Get pvComObject of hoSbRequestBody to vSbRequestBody Get ComPTextSb Of hoHttp "PATCH" sTemp1 vSbRequestBody "utf-8" "application/json" False False 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 // ---------------------------------------------------------------------------------------- // IMPORTANT: // If using Application access, you will get the following error unless you configure your application // to manage online meetings on behalf of the user. (Note that the user ID is in the URL shown above.) // See https://learn.microsoft.com/en-us/graph/cloud-communication-online-meeting-application-access-policy#allow-applications-to-access-online-meetings-on-behalf-of-a-user // // { // "error": { // "code": "General", // "message": "No application access policy found for this app.", // "innerError": { // "request-id": "1c9bd09a-a089-4afd-add4-eec2334135c8", // "date": "2023-11-17T16:26:53", // "client-request-id": "1c9bd09a-a089-4afd-add4-eec2334135c8" // } // } // } // ---------------------------------------------------------------------------------------- Get Create (RefClass(cComChilkatJsonObject)) To hoJsonResp If (Not(IsComObjectCreated(hoJsonResp))) Begin Send CreateComObject of hoJsonResp End Get ComBodyStr Of hoResp To sTemp1 Get ComLoad Of hoJsonResp sTemp1 To iSuccess Set ComEmitCompact Of hoJsonResp To False Get ComEmit Of hoJsonResp To sTemp1 Showln sTemp1 Get ComStatusCode Of hoResp To iStatusCode Showln "response status code = " iStatusCode Send Destroy of hoResp If (iStatusCode <> 200) Begin Showln "Failed." Procedure_Return End // Here is a sample response: // Use the following online tool to generate parsing code from sample JSON: // Generate Parsing Code from JSON // { // "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('4ee732c3-322e-4a6b-b729-2fd1eb5c6004')/onlineMeetings/$entity", // "id": "MSo0ZWU3MzJjMy0zMjJlLTRhNmItYjcyOS0yZmQxZWI1YzYwMDQqMCoqMTk6bWVldGluZ19OemMwT0RGa1pESXRNV1ZoTkMwME9UQXpMV0psWXpJdFkyRXdNR0kzTVeNME5qTmpAdGhyZWFkLnYy", // "creationDateTime": "2023-11-17T18:28:15.9746525Z", // "startDateTime": "2023-12-14T21:33:30Z", // "endDateTime": "2023-12-14T22:03:30Z", // "joinUrl": "https://teams.microsoft.com/l/meetup-join/19%3ameeting_Nzd0ODFkZDItMWVhNC00OTAzLWJlYzItY2EwMGI3MWM0NjNj%40thread.v2/0?context=%7b%22Tid%22%3a%22112d7ed6-71bf-4eba-a866-738364321bfc%22%2c%22Oid%22%3a%224ee732c3-322e-4a6b-b729-2fd1eb5c6004%22%7d", // "meetingCode": "215394732897", // "isBroadcast": false, // "autoAdmittedUsers": "everyoneInCompany", // "outerMeetingAutoAdmittedUsers": null, // "capabilities": [ // ], // "externalId": null, // "iCalUid": null, // "meetingType": null, // "meetingMigrationMode": null, // "joinWebUrl": "https://teams.microsoft.com/l/meetup-join/19%3ameeting_Nzd0ODFkZDItMWVhNC00OTAzLWJlYzItY2EwMGI3MWM0NjNj%40thread.v2/0?context=%7b%22Tid%22%3a%22112d7ed6-71bf-4eba-a866-738364321bfc%22%2c%22Oid%22%3a%224ee732c3-322e-4a6b-b729-2fd1eb5c6004%22%7d", // "subject": "Patch Meeting Subject", // "videoTeleconferenceId": null, // "isEntryExitAnnounced": true, // "allowedPresenters": "everyone", // "allowAttendeeToEnableMic": true, // "allowAttendeeToEnableCamera": true, // "allowMeetingChat": "enabled", // "shareMeetingChatHistoryDefault": "none", // "allowTeamworkReactions": true, // "anonymizeIdentityForRoles": [ // ], // "recordAutomatically": false, // "allowParticipantsToChangeName": false, // "allowTranscription": true, // "allowRecording": true, // "broadcastSettings": null, // "meetingInfo": null, // "audioConferencing": null, // "watermarkProtection": null, // "chatRestrictions": null, // "participants": { // "organizer": { // "upn": "admin@chilkat365.com", // "role": "presenter", // "identity": { // "application": null, // "device": null, // "user": { // "id": "4ee732c3-322e-4a6b-b729-2fd1eb5c6004", // "displayName": null, // "tenantId": "112d7ed6-71bf-4eba-a866-738364321bfc", // "identityProvider": "AAD" // } // } // }, // "attendees": [ // ] // }, // "chatInfo": { // "threadId": "19:meeting_Nzc0ODFkZDItMWVhNC00OTAzLWJlYzItY2EwMGI3MWM0NjNj@thread.v2", // "messageId": "0", // "replyChainMessageId": null // }, // "joinInformation": { // "content": "data:text/html,%3cdiv+style ... %2fdiv%3e", // "contentType": "html" // }, // "joinMeetingIdSettings": { // "isPasscodeRequired": false, // "joinMeetingId": "215394732897", // "passcode": null // }, // "lobbyBypassSettings": { // "scope": "organization", // "isDialInBypassEnabled": false // } // } // Use the following online tool to generate parsing code from sample JSON: // Generate Parsing Code from JSON Showln "Success." End_Procedure |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.