Cross.Messaging
2.0.0
dotnet add package Cross.Messaging --version 2.0.0
NuGet\Install-Package Cross.Messaging -Version 2.0.0
<PackageReference Include="Cross.Messaging" Version="2.0.0" />
<PackageVersion Include="Cross.Messaging" Version="2.0.0" />
<PackageReference Include="Cross.Messaging" />
paket add Cross.Messaging --version 2.0.0
#r "nuget: Cross.Messaging, 2.0.0"
#:package Cross.Messaging@2.0.0
#addin nuget:?package=Cross.Messaging&version=2.0.0
#tool nuget:?package=Cross.Messaging&version=2.0.0
Cross.Messaging
A set of libraries for sending messages across multiple channels.
Current focus:
- Email (
Cross.Messaging.Email.*) - SMS (
Cross.Messaging.Sms.*) - Telegram (
Cross.Messaging.Telegram.*) - Viber (
Cross.Messaging.Viber.*) - WatsApp (
Cross.Messaging.WatsApp.*)
Supported targets: .NET Standard 2.1, .NET 6, .NET 7, .NET 8, .NET 9, .NET 10
Install NuGet package
Install the Cross.Messaging NuGet package into your .NET project:
Install-Package Cross.Messaging
or
dotnet add package Cross.Messaging
Quick start
Register the email sender in DI
services.AddEmailSender(configuration);
AddEmailSender:
- binds the
MessagingEmailconfiguration section toMessagingEmailOptions - registers
IEmailSenderService→EmailSenderService(scoped)
Email sender API
IEmailSenderService currently exposes:
SendAsync(toName, toEmail, subject, body, cancellationToken)SendAsync(toName, toEmail, subject, textBody, htmlBody, attachments, cancellationToken)SendAsyncWithContentIds(toName, toEmail, subject, textBody, htmlBody, attachments, contentIdMap, cancellationToken)
If you use attachment overloads, pass IReadOnlyCollection<IFormFile>? (Microsoft.AspNetCore.Http).
Example:
await emailSender.SendAsync(
toName: "User",
toEmail: "user@example.com",
subject: "Hello",
textBody: "Plain text body",
htmlBody: "<p>HTML body</p>",
attachments: null,
cancellationToken: cancellationToken);
Sample email configuration
{
"MessagingEmail": {
"SmtpHost": "smtp.example.com",
"SmtpPort": 587,
"UseSsl": true,
"SecureSocket": "StartTls",
"SmtpLogin": "login",
"SmtpPassword": "password",
"FromUserName": "App Messaging",
"FromUserAddress": "no-reply@example.com",
"RecipientOverride": ""
}
}
Unit tests
Tests use the Given_When_Then naming style:
- Given — context and preconditions.
- When — the action under test.
- Then — the expected outcome.
Example: Given_ValidSmtpOptions_When_SendAsync_Then_UsesConfiguredHost.
Tests live in Cross.Messaging.Tests/ (for example Email/, Sms/).
Code coverage
Run tests with code coverage (opencover):
dotnet test Cross.Messaging.Tests/Cross.Messaging.Tests.csproj \
--collect:"XPlat Code Coverage" \
--results-directory ./TestResults \
-- DataCollectionRunSettings.DataCollectors.DataCollector.Configuration.Format=opencover
| Product | Versions 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 is compatible. 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 is compatible. 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 is compatible. 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. net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.1 is compatible. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.1
- MailKit (>= 4.16.0)
- Microsoft.AspNetCore.Http.Abstractions (>= 2.3.0)
- Microsoft.Extensions.Configuration (>= 8.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.2)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.3)
- Microsoft.Extensions.Options (>= 8.0.2)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 8.0.0)
-
net10.0
- MailKit (>= 4.16.0)
- Microsoft.AspNetCore.Http.Abstractions (>= 2.3.0)
- Microsoft.Extensions.Configuration (>= 10.0.7)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.7)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.7)
- Microsoft.Extensions.Options (>= 10.0.7)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 10.0.7)
-
net6.0
- MailKit (>= 4.16.0)
- Microsoft.AspNetCore.Http.Abstractions (>= 2.3.0)
- Microsoft.Extensions.Configuration (>= 8.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.2)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.3)
- Microsoft.Extensions.Options (>= 8.0.2)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 8.0.0)
-
net7.0
- MailKit (>= 4.16.0)
- Microsoft.AspNetCore.Http.Abstractions (>= 2.3.0)
- Microsoft.Extensions.Configuration (>= 8.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.2)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.3)
- Microsoft.Extensions.Options (>= 8.0.2)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 8.0.0)
-
net8.0
- MailKit (>= 4.16.0)
- Microsoft.AspNetCore.Http.Abstractions (>= 2.3.0)
- Microsoft.Extensions.Configuration (>= 8.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.2)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.3)
- Microsoft.Extensions.Options (>= 8.0.2)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 8.0.0)
-
net9.0
- MailKit (>= 4.16.0)
- Microsoft.AspNetCore.Http.Abstractions (>= 2.3.0)
- Microsoft.Extensions.Configuration (>= 9.0.15)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.15)
- Microsoft.Extensions.Logging.Abstractions (>= 9.0.15)
- Microsoft.Extensions.Options (>= 9.0.15)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 9.0.15)
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 | 77 | 5/5/2026 |
| 2.0.0-preview.9 | 31 | 5/5/2026 |
| 1.2.0-preview.10 | 30 | 5/5/2026 |
| 1.2.0-preview.9 | 34 | 5/5/2026 |
| 1.2.0-preview.6 | 36 | 5/5/2026 |
| 1.1.4 | 124 | 4/26/2026 |
| 1.1.2 | 132 | 4/17/2026 |
| 1.1.1 | 153 | 4/10/2026 |
| 1.1.0 | 88 | 4/10/2026 |
| 1.1.0-preview.6 | 49 | 4/10/2026 |
| 1.1.0-preview.5 | 49 | 4/10/2026 |
| 1.1.0-preview.4 | 46 | 4/10/2026 |
| 1.1.0-preview.3 | 44 | 4/10/2026 |
| 1.1.0-preview.2 | 48 | 4/10/2026 |
| 1.0.1-preview.2 | 44 | 4/10/2026 |
- Email sender (BREAKING CHANGE): added attachment support in public API (`IFormFile` collections) and implementation.
- Email sender: added `SendAsyncWithContentIds(...)` flow for attachments with custom `Content-ID` mapping.
- Email sender: improved validation for recipient/subject/body parameters and attachment edge cases.
- Logging: updated shared `EmailSendLogging` usage and tests for success/error paths.
- Dependencies: added `Microsoft.AspNetCore.Http.Abstractions` to project and nuspec dependency groups.
- Documentation: expanded XML comments for email services and updated README with current API examples.
- Tests: fixed and expanded unit/integration tests; achieved 100% line/branch/method coverage for `Cross.Messaging`.