Cross.Messaging
2.1.0
dotnet add package Cross.Messaging --version 2.1.0
NuGet\Install-Package Cross.Messaging -Version 2.1.0
<PackageReference Include="Cross.Messaging" Version="2.1.0" />
<PackageVersion Include="Cross.Messaging" Version="2.1.0" />
<PackageReference Include="Cross.Messaging" />
paket add Cross.Messaging --version 2.1.0
#r "nuget: Cross.Messaging, 2.1.0"
#:package Cross.Messaging@2.1.0
#addin nuget:?package=Cross.Messaging&version=2.1.0
#tool nuget:?package=Cross.Messaging&version=2.1.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, body, priority, cancellationToken)SendAsync(toName, toEmail, subject, textBody, htmlBody, cancellationToken)SendAsync(toName, toEmail, subject, textBody, htmlBody, priority, cancellationToken)SendAsync(toName, toEmail, subject, textBody, htmlBody, attachments, cancellationToken)SendAsync(toName, toEmail, subject, textBody, htmlBody, priority, attachments, cancellationToken)SendAsyncWithContentIds(toName, toEmail, subject, textBody, htmlBody, attachments, contentIdMap, cancellationToken)SendAsyncWithContentIds(toName, toEmail, subject, textBody, htmlBody, priority, 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>",
priority: XMessagePriority.Normal,
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": "",
"BccRecipients": [
{
"Name": "Audit Bot",
"Email": "audit@example.com"
}
]
}
}
BccRecipients is optional; when configured, each entry is added to outgoing messages as BCC.
Entries with empty Email are ignored.
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/).
Available NUnit categories:
UnitIntegration
Run only unit tests (NUnit Category=Unit):
dotnet test Cross.Messaging.Tests/Cross.Messaging.Tests.csproj --filter "Category=Unit"
Run only integration tests (NUnit Category=Integration):
dotnet test Cross.Messaging.Tests/Cross.Messaging.Tests.csproj --filter "Category=Integration"
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.1.0 | 127 | 5/8/2026 |
| 2.1.0-preview.1 | 52 | 5/8/2026 |
| 2.0.0 | 97 | 5/5/2026 |
| 2.0.0-preview.9 | 40 | 5/5/2026 |
| 1.2.0-preview.10 | 40 | 5/5/2026 |
| 1.2.0-preview.9 | 45 | 5/5/2026 |
| 1.2.0-preview.6 | 44 | 5/5/2026 |
| 1.1.4 | 129 | 4/26/2026 |
| 1.1.2 | 134 | 4/17/2026 |
| 1.1.1 | 154 | 4/10/2026 |
| 1.1.0 | 89 | 4/10/2026 |
| 1.1.0-preview.6 | 50 | 4/10/2026 |
| 1.1.0-preview.5 | 50 | 4/10/2026 |
| 1.1.0-preview.4 | 47 | 4/10/2026 |
| 1.1.0-preview.3 | 45 | 4/10/2026 |
- Email: added configurable `BccRecipients` in `MessagingEmail` section (`Name`, `Email`) for send flows.
- Email API: added priority overloads for `SendAsync(...)` and `SendAsyncWithContentIds(...)`, plus `SendAsync(...)` overloads without attachments.
- Tests: added category tags (`Unit`, `Integration`) and expanded service tests for new overloads.
- Documentation: updated README examples for API, categories, and category-based test execution.