Unicode C
Unicode C
Microsoft Teams OAuth2 Client Credentials Authentication
See more Microsoft Teams Examples
Demonstrates how to authenticate with OAuth 2.0 using the client credentials grant type.Chilkat Unicode C Downloads
#include <C_CkHttpW.h>
#include <C_CkJsonObjectW.h>
#include <C_CkHttpResponseW.h>
void ChilkatSample(void)
{
BOOL success;
HCkHttpW http;
HCkJsonObjectW jsonOAuthCC;
HCkJsonObjectW json;
HCkHttpResponseW resp;
success = FALSE;
// This requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http = CkHttpW_Create();
// 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.
jsonOAuthCC = CkJsonObjectW_Create();
// --------------------------------------------------------------------------------------------------------
// You'll need to have registered an app in Azure beforehand.
//
// Note: Creating a Team requires the following Application permissions:
// Team.Create, Teamwork.Migrate.All, Group.ReadWrite.All**, Directory.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.
CkJsonObjectW_UpdateString(jsonOAuthCC,L"client_id",L"e1cd2318-xxxx-4916-bfd6-xxxxxxxxxxxx");
CkJsonObjectW_UpdateString(jsonOAuthCC,L"client_secret",L"K.d8Q~RoJxxxxvCj_u_xxxxxxxxxxxxxxxxxxxxx");
// 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.
CkJsonObjectW_UpdateString(jsonOAuthCC,L"scope",L"https://graph.microsoft.com/.default");
// The token endpoint includes your tenant ID. Use your tenant ID (not the tenant ID shown here).
CkJsonObjectW_UpdateString(jsonOAuthCC,L"token_endpoint",L"https://login.microsoftonline.com/112d7ed6-71bf-4eba-a866-738364321bfc/oauth2/v2.0/token");
// Provide the OAuth2 information. Chilkat will use this information to automatically fetch the OAuth2 access token as needed,
CkHttpW_putAuthToken(http,CkJsonObjectW_emit(jsonOAuthCC));
// ------------------------------------------------------------------------------
// To create a Microsoft Team, we want to send an HTTP request like the following:
//
// Note: The following is the minimal JSON for a request using Applicaton permissions (i.e. the access token retrieved using the client credentials grant).
//
// POST https://graph.microsoft.com/v1.0/teams
// Content-Type: application/json
//
// {
// "template@odata.bind":"https://graph.microsoft.com/v1.0/teamsTemplates('standard')",
// "displayName":"My Sample Team",
// "description":"My Sample Team�s Description",
// "members":[
// {
// "@odata.type":"#microsoft.graph.aadUserConversationMember",
// "roles":[
// "owner"
// ],
// "user@odata.bind":"https://graph.microsoft.com/v1.0/users('0040b377-61d8-43db-94f5-81374122dc7e')"
// }
// ]
// }
json = CkJsonObjectW_Create();
CkJsonObjectW_UpdateString(json,L"\"template@odata.bind\"",L"https://graph.microsoft.com/v1.0/teamsTemplates('standard')");
CkJsonObjectW_UpdateString(json,L"displayName",L"My Sample Team");
CkJsonObjectW_UpdateString(json,L"description",L"My Sample Team�s Description");
CkJsonObjectW_UpdateString(json,L"members[0].\"@odata.type\"",L"#microsoft.graph.aadUserConversationMember");
CkJsonObjectW_UpdateString(json,L"members[0].roles[0]",L"owner");
CkJsonObjectW_UpdateString(json,L"members[0].\"user@odata.bind\"",L"https://graph.microsoft.com/v1.0/users('4ee732c3-322e-4a6b-b729-2fd1eb5c6004')");
CkJsonObjectW_putEmitCompact(json,FALSE);
wprintf(L"%s\n",CkJsonObjectW_emit(json));
CkHttpW_SetRequestHeader(http,L"Content-type",L"application/json");
resp = CkHttpResponseW_Create();
success = CkHttpW_HttpJson(http,L"POST",L"https://graph.microsoft.com/v1.0/teams",json,L"application/json",resp);
if (success == FALSE) {
wprintf(L"%s\n",CkHttpW_lastErrorText(http));
CkHttpW_Dispose(http);
CkJsonObjectW_Dispose(jsonOAuthCC);
CkJsonObjectW_Dispose(json);
CkHttpResponseW_Dispose(resp);
return;
}
// A successful response is indicated by a 202 response status code and an empty response body.
wprintf(L"Response Status Code: %d\n",CkHttpResponseW_getStatusCode(resp));
wprintf(L"Response Body:\n");
wprintf(L"%s\n",CkHttpResponseW_bodyStr(resp));
if (CkHttpResponseW_getStatusCode(resp) >= 400) {
wprintf(L"Response Header:\n");
wprintf(L"%s\n",CkHttpResponseW_header(resp));
wprintf(L"Failed.\n");
}
CkHttpW_Dispose(http);
CkJsonObjectW_Dispose(jsonOAuthCC);
CkJsonObjectW_Dispose(json);
CkHttpResponseW_Dispose(resp);
}