Sample code for 30+ languages & platforms
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

Unicode C
#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);

    }