KP.GmailClient
3.0.3
dotnet add package KP.GmailClient --version 3.0.3
NuGet\Install-Package KP.GmailClient -Version 3.0.3
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="KP.GmailClient" Version="3.0.3" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add KP.GmailClient --version 3.0.3
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: KP.GmailClient, 3.0.3"
#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 KP.GmailClient as a Cake Addin #addin nuget:?package=KP.GmailClient&version=3.0.3 // Install KP.GmailClient as a Cake Tool #tool nuget:?package=KP.GmailClient&version=3.0.3
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
KP.GmailClient
This is an alternative client for the auto generated Google.Apis.Gmail.v1 Client Library.
Prerequisites
- Create a new project in the Google Cloud Console (Guide)
- Create a OAuth consent screen (Guide)
- Publish the app or add any test users
- Create Desktop application credentials and download the client secret JSON file (Guide)
- Enable the Gmail API
Setup
One-time setup which opens the browser to authenticate the user.
// Define the required scopes
const GmailScopes scopes = GmailScopes.Readonly | GmailScopes.Send;
var broker = new GmailAuthenticationBroker();
var token = await broker.AuthenticateAsync("oauth_client_credentials.json", scopes);
var tokenStore = new FileTokenStore("token.json");
await tokenStore.StoreTokenAsync(token);
Usage examples
// Use the previously created files
var tokenClient = TokenClient.Create("oauth_client_credentials.json");
var tokenStore = new FileTokenStore("token.json");
using var client = new GmailClient(tokenClient, tokenStore);
// Send a plain text email
Message plainMessage = await client.Messages.SendAsync("example@gmail.com", "Subject", "Plain text body");
// Send a HTML email
Message htmlMessage = await client.Messages.SendAsync("example@gmail.com", "Subject", "<h1>HTML body</h1>", isBodyHtml: true);
// Get the users profile
Profile profile = await client.GetProfileAsync();
// Get inbox messages
IList<Message> messages = await client.Messages.ListAsync();
// Get starred messages
IList<Message> starredMessages = await client.Messages.ListByLabelAsync(Label.Starred);
// List all labels
IList<Label> labels = await client.Labels.ListAsync();
// List all drafts
IList<Draft> drafts = await client.Drafts.ListAsync();
Product | Versions 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. |
.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.
-
.NETStandard 2.0
- System.Net.Http.Json (>= 6.0.0)
- System.Text.Json (>= 6.0.6)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.