NullEmailSender.cs 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. using System.Net.Mail;
  2. using System.Threading.Tasks;
  3. using Castle.Core.Logging;
  4. namespace Abp.Net.Mail
  5. {
  6. /// <summary>
  7. /// This class is an implementation of <see cref="IEmailSender"/> as similar to null pattern.
  8. /// It does not send emails but logs them.
  9. /// </summary>
  10. public class NullEmailSender : EmailSenderBase
  11. {
  12. public ILogger Logger { get; set; }
  13. /// <summary>
  14. /// Creates a new <see cref="NullEmailSender"/> object.
  15. /// </summary>
  16. /// <param name="configuration">Configuration</param>
  17. public NullEmailSender(IEmailSenderConfiguration configuration)
  18. : base(configuration)
  19. {
  20. Logger = NullLogger.Instance;
  21. }
  22. protected override Task SendEmailAsync(MailMessage mail)
  23. {
  24. Logger.Warn("USING NullEmailSender!");
  25. Logger.Debug("SendEmailAsync:");
  26. LogEmail(mail);
  27. return Task.FromResult(0);
  28. }
  29. protected override void SendEmail(MailMessage mail)
  30. {
  31. Logger.Warn("USING NullEmailSender!");
  32. Logger.Debug("SendEmail:");
  33. LogEmail(mail);
  34. }
  35. private void LogEmail(MailMessage mail)
  36. {
  37. Logger.Debug(mail.To.ToString());
  38. Logger.Debug(mail.CC.ToString());
  39. Logger.Debug(mail.Subject);
  40. Logger.Debug(mail.Body);
  41. }
  42. }
  43. }