Com.H.GraphAPI 2.0.0

dotnet add package Com.H.GraphAPI --version 2.0.0                
NuGet\Install-Package Com.H.GraphAPI -Version 2.0.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="Com.H.GraphAPI" Version="2.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Com.H.GraphAPI --version 2.0.0                
#r "nuget: Com.H.GraphAPI, 2.0.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 Com.H.GraphAPI as a Cake Addin
#addin nuget:?package=Com.H.GraphAPI&version=2.0.0

// Install Com.H.GraphAPI as a Cake Tool
#tool nuget:?package=Com.H.GraphAPI&version=2.0.0                

Com.H.GraphAPI

Simplified way to use Microsoft Graph API in .NET applications. In its current initial release, it supports authenticating and sending emails only.

Kindly visit the project's github page for documentation https://github.com/H7O/Com.H.GraphAPI

This library supports all .NET releases, .NET 4.x frameworks (.NET 4.6 to 4.8.x) and also .NET Core / 5 / 6 / 7 / 8+

Installation

Nuget

Install-Package Com.H.GraphAPI

.NET CLI

dotnet add package Com.H.GraphAPI

Usage

Sample 1

Authenticating and receiving an access token then sending an email using the account to which the access token is issued.

string clientId = "Your Client ID";
string clientSecret = "Your Client Secret";
string tenantId = "Your Tenant ID";

var accessToken =
    Com.H.GraphAPI.Identity.GIExtensions
    .GetAccessToken(clientId, clientSecret, tenantId); 
    // use the "GetAccessTokenAsync" method to request the token asynchronously.
                

Com.H.GraphAPI.Mail.Message msg = new Com.H.GraphAPI.Mail.Message();

msg.From = "yourName@yourCompany.com";
msg.To.Add("yourName@yourCompany.com");
msg.Subject = "Testing MS Graph API";
msg.Body = "This is a test email sent via <strong>MS Graph API</strong>";

// read from a file path
msg.Attachments.Add(@"c:\temp\email\test1.txt");
msg.Attachments.Add(@"c:\temp\email\test2.txt");

// add content directly
msg.Attachments.AddContent("direct content test", "test3.txt");

var result = msg.Send(accessToken); // use the "SendAsync" method to send the email asynchronously.

if (result.IsSuccessStatusCode)
{
    Console.WriteLine("Email sent successfully");
}
else
{
    Console.WriteLine("Email failed to send");
}

Sample 2

Authenticating and receiving an access token then sending an email using the account to which the access token is issued. Also, the sample shows how to re-use the same access token for multiple requests while it is still valid (i.e, hasn't yet expired). And also shows how to attach a file from a stream.

string clientId = "Your Client ID";
string clientSecret = "Your Client Secret";
string tenantId = "Your Tenant ID";


Com.H.GraphAPI.Mail.Message msg = new Com.H.GraphAPI.Mail.Message();

// the following delegate gets called, under the hood by the Send() method, 
// before sending the email to obtain an access token.
msg.GetAccessTokenDelegate = () =>
{
    // you can return your previously issued access token here if it's still valid
    // otherwise, you can issue a new access token here.

    // you can use the following code sample to issue a new access token
    var accessTokenWithExpiryInfo =
        Com.H.GraphAPI.Identity.GIExtensions
        .GetAccessTokenWithExpiryDate(clientId, clientSecret, tenantId); 
        // async version of the above is also available

    if (string.IsNullOrWhiteSpace(accessTokenWithExpiryInfo.AccessToken))
    {
        Console.WriteLine("Error obtaining access token");
        // your logic to log the error goes here

        // the following exception will be thrown when calling msg.Send()
        throw new Exception("Error obtaining access token");
    }

    Console.WriteLine($"access token expires on {accessTokenWithExpiryInfo.ExpiresOn}");
    return accessTokenWithExpiryInfo.AccessToken;

}; ;


msg.From = "yourName@yourCompany.com";
msg.To.Add("yourName@yourCompany.com");
msg.Subject = "Testing MS Graph API";
msg.Body = "This is a test email sent via <strong>MS Graph API</strong>";

// read from a file path
msg.Attachments.Add(@"c:\temp\email\test1.txt");
msg.Attachments.Add(@"c:\temp\email\test2.txt");

// add content directly
msg.Attachments.AddContent("direct content test", "test3.txt");

// read from an IO Stream
using (var fs = new FileStream(@"c:\temp\email\test4.txt", FileMode.Open, FileAccess.Read))
{
    msg.Attachments.Add(fs, "test4.txt");
    // the stream can be safely closed here as it will be copied to a memory stream under the hood.
}

var result = msg.Send();
            
if (result.IsSuccessStatusCode)
{
    Console.WriteLine("Email sent successfully");
}
else
{
    Console.WriteLine("Email failed to send");
}


Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  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.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.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 was computed.  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

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.0.0 229 7/9/2023

Small initial release for a Graph API wrapper containing, in its current form, a very small collection of helpful functionalties for Azure authentication and sending emails using Graph Rest API.