MailHandler.php 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. <?php
  2. namespace Drupal\contact;
  3. use Drupal\Core\Entity\EntityTypeManagerInterface;
  4. use Drupal\Core\Language\LanguageManagerInterface;
  5. use Drupal\Core\Mail\MailManagerInterface;
  6. use Drupal\Core\Session\AccountInterface;
  7. use Drupal\Core\StringTranslation\StringTranslationTrait;
  8. use Drupal\Core\StringTranslation\TranslationInterface;
  9. use Psr\Log\LoggerInterface;
  10. /**
  11. * Provides a class for handling assembly and dispatch of contact mail messages.
  12. */
  13. class MailHandler implements MailHandlerInterface {
  14. use StringTranslationTrait;
  15. /**
  16. * Language manager service.
  17. *
  18. * @var \Drupal\Core\Language\LanguageManagerInterface
  19. */
  20. protected $languageManager;
  21. /**
  22. * Logger service.
  23. *
  24. * @var \Drupal\Core\Logger\LoggerChannelInterface
  25. */
  26. protected $logger;
  27. /**
  28. * Mail manager service.
  29. *
  30. * @var \Drupal\Core\Mail\MailManagerInterface
  31. */
  32. protected $mailManager;
  33. /**
  34. * The user entity storage handler.
  35. *
  36. * @var \Drupal\Core\Entity\EntityStorageInterface
  37. */
  38. protected $userStorage;
  39. /**
  40. * Constructs a new \Drupal\contact\MailHandler object.
  41. *
  42. * @param \Drupal\Core\Mail\MailManagerInterface $mail_manager
  43. * Mail manager service.
  44. * @param \Drupal\Core\Language\LanguageManagerInterface $language_manager
  45. * Language manager service.
  46. * @param \Psr\Log\LoggerInterface $logger
  47. * A logger instance.
  48. * @param \Drupal\Core\StringTranslation\TranslationInterface $string_translation
  49. * String translation service.
  50. * @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
  51. * The entity type manager.
  52. */
  53. public function __construct(MailManagerInterface $mail_manager, LanguageManagerInterface $language_manager, LoggerInterface $logger, TranslationInterface $string_translation, EntityTypeManagerInterface $entity_type_manager) {
  54. $this->languageManager = $language_manager;
  55. $this->mailManager = $mail_manager;
  56. $this->logger = $logger;
  57. $this->stringTranslation = $string_translation;
  58. $this->userStorage = $entity_type_manager->getStorage('user');
  59. }
  60. /**
  61. * {@inheritdoc}
  62. */
  63. public function sendMailMessages(MessageInterface $message, AccountInterface $sender) {
  64. // Clone the sender, as we make changes to mail and name properties.
  65. $sender_cloned = clone $this->userStorage->load($sender->id());
  66. $params = [];
  67. $current_langcode = $this->languageManager->getCurrentLanguage()->getId();
  68. $recipient_langcode = $this->languageManager->getDefaultLanguage()->getId();
  69. $contact_form = $message->getContactForm();
  70. if ($sender_cloned->isAnonymous()) {
  71. // At this point, $sender contains an anonymous user, so we need to take
  72. // over the submitted form values.
  73. $sender_cloned->name = $message->getSenderName();
  74. $sender_cloned->mail = $message->getSenderMail();
  75. // For the email message, clarify that the sender name is not verified; it
  76. // could potentially clash with a username on this site.
  77. $sender_cloned->name = $this->t('@name (not verified)', ['@name' => $message->getSenderName()]);
  78. }
  79. // Build email parameters.
  80. $params['contact_message'] = $message;
  81. $params['sender'] = $sender_cloned;
  82. if (!$message->isPersonal()) {
  83. // Send to the form recipient(s), using the site's default language.
  84. $params['contact_form'] = $contact_form;
  85. $to = implode(', ', $contact_form->getRecipients());
  86. }
  87. elseif ($recipient = $message->getPersonalRecipient()) {
  88. // Send to the user in the user's preferred language.
  89. $to = $recipient->getEmail();
  90. $recipient_langcode = $recipient->getPreferredLangcode();
  91. $params['recipient'] = $recipient;
  92. }
  93. else {
  94. throw new MailHandlerException('Unable to determine message recipient');
  95. }
  96. // Send email to the recipient(s).
  97. $key_prefix = $message->isPersonal() ? 'user' : 'page';
  98. $this->mailManager->mail('contact', $key_prefix . '_mail', $to, $recipient_langcode, $params, $sender_cloned->getEmail());
  99. // If requested, send a copy to the user, using the current language.
  100. if ($message->copySender()) {
  101. $this->mailManager->mail('contact', $key_prefix . '_copy', $sender_cloned->getEmail(), $current_langcode, $params, $sender_cloned->getEmail());
  102. }
  103. // If configured, send an auto-reply, using the current language.
  104. if (!$message->isPersonal() && $contact_form->getReply()) {
  105. // User contact forms do not support an auto-reply message, so this
  106. // message always originates from the site.
  107. if (!$sender_cloned->getEmail()) {
  108. $this->logger->error('Error sending auto-reply, missing sender e-mail address in %contact_form', [
  109. '%contact_form' => $contact_form->label(),
  110. ]);
  111. }
  112. else {
  113. $this->mailManager->mail('contact', 'page_autoreply', $sender_cloned->getEmail(), $current_langcode, $params);
  114. }
  115. }
  116. if (!$message->isPersonal()) {
  117. $this->logger->notice('%sender-name (@sender-from) sent an email regarding %contact_form.', [
  118. '%sender-name' => $sender_cloned->getAccountName(),
  119. '@sender-from' => $sender_cloned->getEmail(),
  120. '%contact_form' => $contact_form->label(),
  121. ]);
  122. }
  123. else {
  124. $this->logger->notice('%sender-name (@sender-from) sent %recipient-name an email.', [
  125. '%sender-name' => $sender_cloned->getAccountName(),
  126. '@sender-from' => $sender_cloned->getEmail(),
  127. '%recipient-name' => $message->getPersonalRecipient()->getAccountName(),
  128. ]);
  129. }
  130. }
  131. }