btcpayserver/BTCPayServer/Services/Mails/EmailSettings.cs

67 lines
2.5 KiB
C#
Raw Normal View History

2021-12-31 16:59:02 +09:00
using System.Threading;
using System.Threading.Tasks;
2022-03-11 10:17:50 +01:00
using BTCPayServer.Client.Models;
2021-12-31 16:59:02 +09:00
using MailKit.Net.Smtp;
using MimeKit;
2017-09-27 14:18:09 +09:00
namespace BTCPayServer.Services.Mails
{
public class EmailSettings : EmailSettingsData
2017-09-27 14:18:09 +09:00
{
public bool IsComplete()
{
return !string.IsNullOrWhiteSpace(Server) && Port is int;
}
2017-09-27 14:18:09 +09:00
public MimeMessage CreateMailMessage(MailboxAddress to, string subject, string message, bool isHtml) =>
CreateMailMessage(new[] {to}, null, null, subject, message, isHtml);
public MimeMessage CreateMailMessage(MailboxAddress[] to, MailboxAddress[] cc, MailboxAddress[] bcc, string subject, string message, bool isHtml)
2018-05-05 01:42:42 +09:00
{
var bodyBuilder = new BodyBuilder();
if (isHtml)
2018-05-05 01:42:42 +09:00
{
bodyBuilder.HtmlBody = message;
2018-05-05 01:42:42 +09:00
}
else
{
bodyBuilder.TextBody = message;
}
var mm = new MimeMessage();
mm.Body = bodyBuilder.ToMessageBody();
mm.Subject = subject;
mm.From.Add(new MailboxAddress(From, !string.IsNullOrWhiteSpace(FromDisplay) ? From : FromDisplay));
mm.To.AddRange(to);
mm.Cc.AddRange(cc?? System.Array.Empty<InternetAddress>());
mm.Bcc.AddRange(bcc?? System.Array.Empty<InternetAddress>());
return mm;
}
public async Task<SmtpClient> CreateSmtpClient()
{
SmtpClient client = new SmtpClient();
using var connectCancel = new CancellationTokenSource(10000);
try
{
if (Extensions.IsLocalNetwork(Server))
{
client.CheckCertificateRevocation = false;
#pragma warning disable CA5359 // Do Not Disable Certificate Validation
client.ServerCertificateValidationCallback = (s, c, h, e) => true;
#pragma warning restore CA5359 // Do Not Disable Certificate Validation
}
await client.ConnectAsync(Server, Port.Value, MailKit.Security.SecureSocketOptions.Auto, connectCancel.Token);
if ((client.Capabilities & SmtpCapabilities.Authentication) != 0)
await client.AuthenticateAsync(Login ?? string.Empty, Password ?? string.Empty, connectCancel.Token);
}
catch
{
client.Dispose();
throw;
}
return client;
}
}
2017-09-27 14:18:09 +09:00
}