Aethel.Services.Emissary
1.0.1
dotnet add package Aethel.Services.Emissary --version 1.0.1
NuGet\Install-Package Aethel.Services.Emissary -Version 1.0.1
<PackageReference Include="Aethel.Services.Emissary" Version="1.0.1" />
paket add Aethel.Services.Emissary --version 1.0.1
#r "nuget: Aethel.Services.Emissary, 1.0.1"
// Install Aethel.Services.Emissary as a Cake Addin #addin nuget:?package=Aethel.Services.Emissary&version=1.0.1 // Install Aethel.Services.Emissary as a Cake Tool #tool nuget:?package=Aethel.Services.Emissary&version=1.0.1
Emissary
Version inicial
Emissary es un enviador de correos de sistema con implementacion inicial SMTP, pero abierto a futuras implementaciones basadas en la interface IMailService, es decir, las futuras implementaciones con SendGrid por ejemplo, como cliente de envio de correos de sistema se agregarán a Emissary sin necesidad de cambiar las implementaciones que tengas en los proyectos. Emissary es una capa de abstraccion para los envios empresariales, que se inyecta en los servicios de una aplicacion y centraliza la configuracion de tu instancia, dejando una implementacion limpia, pues solo necesitas especificar el destinatario, el subject y el contenido.
Features
- Implementacion del servicio de correos utilizando MailKit y MimeTypes bajo el capo
- Configuracion centralizada en el startup para configuraciones generales de Emissary y especificas de SMTP
- Se expone solo un metodo para envio de correos empresariales, en el futuro se agregaran los necesarios
Configuracion
Para integrar Emissary solo necesitamos realizar una configuracion cuando lo agregamos a la inyeccion de dependencias de NetCore.
var services = new ServiceCollection();
// some configurations
services.AddEmissary(options =>{
options.Name = "Sistem Name",
options.Address = "Server Email Address",
options.UseSmtpClient(smtp =>{
smtp.Host = "Smtp hots";
smtp.Port = Smtp Port;
smtp.Username = "Username to login";
smtp.Password = "Password to login"
});
});
Por el momento, Emissary solo tiene la implementacion de servicio de correos utilizando SMTP, es por eso que la configuracion utiliza SMTP. En futuros releases se agregaran otros clientes y servicios de correo como Sendgrid. Para utilizar el servicio de correo solo basta inyectar en el sitio donde lo vamos a utilizar la interfaz IMailService, y con eso, tendremos acceso al servicio de correos configurado con los datos presentados arriba. Para enviar un mensaje, tan solo debemos de crear el objeto Message que define lo necesario para enviar el mensaje a traves del servicio de correo.
public class SomeClass{
private readonly IMailService _mailService;
public SomeClass(IMailService mailService){
_mailService = mailService
}
public Task SomeMethod(){
// Se ejecuta de forma asincrona por default
await _mailService.SendSystemEmailAsync(new Message{
Subject = "Tu asunto",
Recipient = new Contact{ Name = "Nombre del destinatario", Address = "Direccion del usuario" },
Content = "Tu contenido en html"
});
}
}
Con estos dos pasos podemos enviar los correos de sistema que necesitemos y en caso de cambiar la direccion de correo desde donde envian, pueden manejar estas modificaciones desde el appsettings.
Versiones y fechas de lanzamiento
Version | Fecha de lanzamiento | Features | Status |
---|---|---|---|
1.0.0 | Mar 2020 | Arquitectura para futuras implementaciones sin modificaciones en como los usuarios finales lo utilizan, uso de smtp para el envio de correos bajo el capo | Liberada |
License
MIT
If it works, learn how it do
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | 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. |
-
net6.0
- MailKit (>= 3.1.1)
- Microsoft.Extensions.DependencyInjection (>= 6.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 6.0.0)
- Microsoft.Extensions.Options (>= 6.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
El servicio de IMailService se hace singleton para acceder a nivel general