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

Objective-C
#import <CkoHttp.h>
#import <CkoJsonObject.h>
#import <CkoHttpResponse.h>

BOOL success = NO;

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

CkoHttp *http = [[CkoHttp alloc] init];

// 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.  
CkoJsonObject *jsonOAuthCC = [[CkoJsonObject alloc] init];

// --------------------------------------------------------------------------------------------------------
// 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.
[jsonOAuthCC UpdateString: @"client_id" value: @"e1cd2318-xxxx-4916-bfd6-xxxxxxxxxxxx"];
[jsonOAuthCC UpdateString: @"client_secret" value: @"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.
[jsonOAuthCC UpdateString: @"scope" value: @"https://graph.microsoft.com/.default"];

// The token endpoint includes your tenant ID.  Use your tenant ID (not the tenant ID shown here).
[jsonOAuthCC UpdateString: @"token_endpoint" value: @"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,
http.AuthToken = [jsonOAuthCC Emit];

// ------------------------------------------------------------------------------
// 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')"
//       }
//    ]
// }

CkoJsonObject *json = [[CkoJsonObject alloc] init];
[json UpdateString: @"\"template@odata.bind\"" value: @"https://graph.microsoft.com/v1.0/teamsTemplates('standard')"];
[json UpdateString: @"displayName" value: @"My Sample Team"];
[json UpdateString: @"description" value: @"My Sample Team�s Description"];
[json UpdateString: @"members[0].\"@odata.type\"" value: @"#microsoft.graph.aadUserConversationMember"];
[json UpdateString: @"members[0].roles[0]" value: @"owner"];
[json UpdateString: @"members[0].\"user@odata.bind\"" value: @"https://graph.microsoft.com/v1.0/users('4ee732c3-322e-4a6b-b729-2fd1eb5c6004')"];

json.EmitCompact = NO;
NSLog(@"%@",[json Emit]);

[http SetRequestHeader: @"Content-type" value: @"application/json"];

CkoHttpResponse *resp = [[CkoHttpResponse alloc] init];
success = [http HttpJson: @"POST" url: @"https://graph.microsoft.com/v1.0/teams" json: json contentType: @"application/json" response: resp];
if (success == NO) {
    NSLog(@"%@",http.LastErrorText);
    return;
}

// A successful response is indicated by a 202 response status code and an empty response body.
NSLog(@"%@%d",@"Response Status Code: ",[resp.StatusCode intValue]);
NSLog(@"%@",@"Response Body:");
NSLog(@"%@",resp.BodyStr);

if ([resp.StatusCode intValue] >= 400) {
    NSLog(@"%@",@"Response Header:");
    NSLog(@"%@",resp.Header);
    NSLog(@"%@",@"Failed.");
}