Microsoft.Graph.Core 3.2.0

Prefix Reserved
dotnet add package Microsoft.Graph.Core --version 3.2.0                
NuGet\Install-Package Microsoft.Graph.Core -Version 3.2.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Microsoft.Graph.Core" Version="3.2.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Microsoft.Graph.Core --version 3.2.0                
#r "nuget: Microsoft.Graph.Core, 3.2.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Microsoft.Graph.Core as a Cake Addin
#addin nuget:?package=Microsoft.Graph.Core&version=3.2.0

// Install Microsoft.Graph.Core as a Cake Tool
#tool nuget:?package=Microsoft.Graph.Core&version=3.2.0                

Microsoft Graph .NET Core Client Library

Build Status NuGet Version

Integrate the Microsoft Graph API into your .NET project!

The Microsoft Graph .NET Core Client Library contains core classes and interfaces used by Microsoft.Graph Client Library to send native HTTP requests to Microsoft Graph API. The latest core client library targets .NetStandard 2.0.

Installation via NuGet

To install the client library via NuGet:

  • Search for Microsoft.Graph.Core in the NuGet Library, or
  • Type Install-Package Microsoft.Graph.Core into the Package Manager Console.

Getting started

1. Register your application

Register your application to use Microsoft Graph API by following the steps at Register your application with the Microsoft identity platform.

2. Authenticate for the Microsoft Graph service

The Microsoft Graph .NET Client Library supports the use of TokenCredential classes in the Azure.Identity library.

You can read more about available Credential classes here and examples on how to quickly setup TokenCredential instances can be found here.

The recommended library for authenticating against Microsoft Identity (Azure AD) is MSAL.

For an example of authenticating a UWP app using the V2 Authentication Endpoint, see the Microsoft Graph UWP Connect Library.

3. Create a HttpClient object with an authentication provider

You can create an instance of HttpClient that is pre-configured for making requests to Microsoft Graph APIs using GraphClientFactory.

// The client credentials flow requires that you request the
// /.default scope, and pre-configure your permissions on the
// app registration in Azure. An administrator must grant consent
// to those permissions beforehand.
var scopes = new[] { "https://graph.microsoft.com/.default" };

// Values from app registration
var clientId = "YOUR_CLIENT_ID";
var tenantId = "YOUR_TENANT_ID";
var clientSecret = "YOUR_CLIENT_SECRET";

// using Azure.Identity;
var options = new ClientSecretCredentialOptions
{
    AuthorityHost = AzureAuthorityHosts.AzurePublicCloud,
};

// https://learn.microsoft.com/dotnet/api/azure.identity.clientsecretcredential
var clientSecretCredential = new ClientSecretCredential(
    tenantId, clientId, clientSecret, options);

HttpClient httpClient = GraphClientFactory.create(tokenCredential: clientSecretCredential, version: "beta");

For more information on initializing a client instance, see the library overview

4. Make requests to the graph

Once you have an authenticated HttpClient, you can begin to make calls to the service. The requests to the service follows our REST API syntax.

For example, to retrieve a user's default drive:

HttpRequestMessage requestMessage = new HttpRequestMessage(HttpMethod.Get, "me/drive");
HttpResponseMessage response = await httpClient.SendAsync(requestMessage);
if (response.IsSuccessStatusCode)
{
    string jsonResponse = await response.Content.ReadAsStringAsync();
}

To get the current user's root folder of their default drive:

HttpRequestMessage requestMessage = new HttpRequestMessage(HttpMethod.Get, "me/drive/root");
HttpResponseMessage response = await httpClient.SendAsync(requestMessage);
if (response.IsSuccessStatusCode)
{
    string jsonResponse = await response.Content.ReadAsStringAsync();
}

Documentation and resources

Notes

Install System.Runtime.InteropServices.RuntimeInformation before you install Microsoft.Graph >=1.3 if you are having an issue updating the package for a Xamarin solution. You may need to updated references to Microsoft.NETCore.UniversalWindowsPlatform to >=5.2.2 as well.

Issues

To view or log issues, see issues.

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.

Other resources

Building library locally

If you are looking to build the library locally for the purposes of contributing code or running tests, you will need to:

  • Have the .NET Core SDK (> 1.0) installed
  • Run dotnet restore from the command line in your package directory
  • Run nuget restore and msbuild from CLI or run Build from Visual Studio to restore Nuget packages and build the project

Run dotnet build -p:IncludeMauiTargets=true if you wish to build the MAUI targets for the projects as well.

License

Copyright (c) Microsoft Corporation. All Rights Reserved. Licensed under the MIT license. See Third Party Notices for information on the packages referenced via NuGet.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 is compatible.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (39)

Showing the top 5 NuGet packages that depend on Microsoft.Graph.Core:

Package Downloads
Microsoft.Graph

Microsoft Graph Client Library allows you to call Office 365, Azure AD and other Microsoft services through a single unified developer experience.

Microsoft.Graph.Auth

Microsoft Graph Authentication Library implements authentication functionality used by Microsoft Graph Client Library. It provides a set of OAuth scenario-centric providers that implement Microsoft.Graph.IAuthenticationProvider and uses Microsoft Authentication Library (MSAL) to handle access token acquisition and storage.

Microsoft.Graph.Beta

Microsoft Graph beta client library allows you to target the Microsoft Graph /beta endpoint. You can call Office 365, Azure AD and other Microsoft services through a single unified developer experience.

PnP.Framework

PnP Framework contains the PnP Provisioning engine and a ton of extension methods that will make you more productive while developing for Microsoft 365.

Microsoft.Graph.Communications.Core

Microsoft Graph Communications Client Core Library - This library builds on the Microsoft.Graph SDK to provide better support for the Communications APIs.

GitHub repositories (25)

Showing the top 5 popular GitHub repositories that depend on Microsoft.Graph.Core:

Repository Stars
ONLYOFFICE/CommunityServer
Free open source office suite with business productivity tools: document and project management, CRM, mail aggregator.
pnp/PnP
SharePoint / Office 365 Developer Patterns and Practices - Archived older solutions. Please see https://aka.ms/m365pnp for updated guidance
OfficeDev/Microsoft-Teams-Samples
Welcome to the Microsoft Teams samples repository. Here you will find task-focused samples in C#, JavaScript and TypeScript to help you get started with the Microsoft Teams App!
pnp/PnP-PowerShell
SharePoint PnP PowerShell CmdLets
microsoftgraph/msgraph-sdk-powershell
Powershell SDK for Microsoft Graph
Version Downloads Last updated
3.2.0 7,053 11/8/2024
3.1.22 971,093 9/26/2024
3.1.21 573,283 9/4/2024
3.1.20 21,111 8/28/2024
3.1.19 236,087 8/26/2024
3.1.18 1,215 8/26/2024
3.1.17 15,958 8/19/2024
3.1.16 5,619 8/15/2024
3.1.15 25,165 8/9/2024
3.1.14 43,846 7/24/2024
3.1.13 76,283 7/3/2024
3.1.12 3,938,123 5/28/2024
3.1.11 1,034,750 4/30/2024
3.1.10 1,170,809 3/28/2024
3.1.9 518,642 3/18/2024
3.1.8 1,354,065 2/16/2024
3.1.8-preview.1 119 2/27/2024
3.1.7 302,221 2/9/2024
3.1.6 1,827,116 1/23/2024
3.1.5 357,332 1/15/2024
3.1.4 38,704 1/9/2024
3.1.3 1,033,655 11/29/2023
3.1.2 1,177,880 11/15/2023
3.1.1 236,755 11/7/2023
3.1.0 376,259 10/24/2023
3.0.11 1,216,274 9/5/2023
3.0.11-preview.1 236 9/1/2023
3.0.10 824,432 8/8/2023
3.0.10-preview.1 732 7/13/2023
3.0.9 1,056,805 6/29/2023
3.0.9-preview.1 218 6/29/2023
3.0.8 10,174 6/27/2023
3.0.7 688,488 5/30/2023
3.0.6 1,353,799 4/18/2023
3.0.6-preview.1 200 4/18/2023
3.0.5 651,190 3/30/2023
3.0.4 163,207 3/27/2023
3.0.3 213,779 3/21/2023
3.0.2 170,279 3/13/2023
3.0.1 137,371 3/7/2023
3.0.0 204,104 2/28/2023
3.0.0-rc.6 9,104 2/9/2023
3.0.0-rc.5 4,474 1/26/2023
3.0.0-rc.4 285 1/25/2023
3.0.0-rc.3 3,827 1/18/2023
3.0.0-rc.2 1,857 1/11/2023
3.0.0-rc.1 12,165 12/16/2022
3.0.0-preview.19 287 12/14/2022
3.0.0-preview.18 447 12/6/2022
3.0.0-preview.17 102,077 11/23/2022
3.0.0-preview.16 122,537 10/18/2022
3.0.0-preview.15 472 10/3/2022
3.0.0-preview.14 7,026 9/28/2022
3.0.0-preview.13 2,444 9/6/2022
3.0.0-preview.12 468 8/29/2022
3.0.0-preview.11 81,840 7/20/2022
3.0.0-preview.10 2,322 7/13/2022
3.0.0-preview.9 21,940 6/21/2022
3.0.0-preview.8 2,118 6/9/2022
3.0.0-preview.7 1,554 5/31/2022
3.0.0-preview.6 6,078 5/20/2022
3.0.0-preview.5 13,904 5/4/2022
3.0.0-preview.4 4,034 4/13/2022
3.0.0-preview.3 363 4/12/2022
3.0.0-preview.2 1,583 4/1/2022
3.0.0-preview.1 2,335 3/22/2022
2.0.15 4,374,696 2/9/2023
2.0.14 8,857,511 10/11/2022
2.0.13 978,247 9/27/2022
2.0.13-preview.1 268 9/26/2022
2.0.12 3,571,421 8/24/2022
2.0.11 1,926,296 8/11/2022
2.0.10 955,545 7/20/2022
2.0.9 5,149,215 6/9/2022
2.0.8 5,876,399 2/18/2022
2.0.7 3,882,316 12/16/2021
2.0.6 316,382 12/2/2021
2.0.5 6,921,669 9/1/2021
2.0.4 54,012 8/24/2021
2.0.3 404,860 8/17/2021
2.0.2 718,939 8/11/2021
2.0.1 179,584 8/5/2021
2.0.0 561,787 7/22/2021
2.0.0-preview.14 2,496 7/7/2021
2.0.0-preview.13 46,820 6/18/2021
2.0.0-preview.12 44,080 6/7/2021
2.0.0-preview.11 61,812 5/7/2021
2.0.0-preview.10 45,790 4/21/2021
2.0.0-preview.9 25,206 4/1/2021
2.0.0-preview.8 40,184 3/17/2021
2.0.0-preview.7 616 3/2/2021
2.0.0-preview.6 474 2/24/2021
2.0.0-preview.5 352 2/24/2021
2.0.0-preview.4 5,146 1/6/2021
2.0.0-preview.3 29,188 4/29/2020
2.0.0-preview.2 2,547 4/9/2020
2.0.0-preview.1 16,549 3/9/2020
1.25.1 11,823,779 3/25/2021
1.25.1-preview.2 338 3/25/2021
1.25.1-preview.1 357 3/25/2021
1.25.0 285,905 3/25/2021
1.25.0-preview.2 371 3/20/2021
1.25.0-preview.1 573 3/17/2021
1.24.0 3,444,827 1/19/2021
1.24.0-preview.1 363 1/14/2021
1.23.0 3,020,078 11/26/2020
1.22.0 3,517,864 10/7/2020
1.22.0-preview.2 448 10/6/2020
1.22.0-preview.1 455 7/28/2020
1.21.0 3,834,935 7/28/2020
1.21.0-preview.1 3,105 6/19/2020
1.20.1 5,615,449 3/31/2020
1.20.0 7,562,388 2/5/2020
1.19.0 2,893,180 12/11/2019
1.18.0 1,428,152 10/10/2019
1.17.0 939,926 8/15/2019
1.16.0 128,825 7/3/2019
1.15.0 2,282,570 5/1/2019
1.14.1 165,242 3/29/2019
1.14.0 1,398,070 3/25/2019
1.12.0 1,389,630 10/31/2018
1.11.0 318,204 9/19/2018
1.10.0 424,442 7/6/2018
1.9.0 1,696,003 5/3/2018
1.8.1 221,276 3/23/2018
1.7.0 202,865 12/14/2017
1.6.2 170,714 9/26/2017
1.6.1 84,249 8/24/2017
1.6.0 51,778 8/8/2017
1.5.0 257,593 6/12/2017
1.4.0 310,068 5/10/2017
1.3.1 74,082 4/3/2017
1.3.0 211,918 11/8/2016
1.2.1 146,307 9/27/2016
1.1.1 12,301 8/8/2016
1.1.0 5,265 8/6/2016