BaseMessage.php 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <?php
  2. /**
  3. * @link https://www.yiiframework.com/
  4. * @copyright Copyright (c) 2008 Yii Software LLC
  5. * @license https://www.yiiframework.com/license/
  6. */
  7. namespace yii\mail;
  8. use Yii;
  9. use yii\base\BaseObject;
  10. use yii\base\ErrorHandler;
  11. /**
  12. * BaseMessage serves as a base class that implements the [[send()]] method required by [[MessageInterface]].
  13. *
  14. * By default, [[send()]] will use the "mailer" application component to send the current message.
  15. * The "mailer" application component should be a mailer instance implementing [[MailerInterface]].
  16. *
  17. * @see BaseMailer
  18. *
  19. * @author Paul Klimov <klimov.paul@gmail.com>
  20. * @since 2.0
  21. */
  22. abstract class BaseMessage extends BaseObject implements MessageInterface
  23. {
  24. /**
  25. * @var MailerInterface|null the mailer instance that created this message.
  26. * For independently created messages this is `null`.
  27. */
  28. public $mailer;
  29. /**
  30. * Sends this email message.
  31. * @param MailerInterface|null $mailer the mailer that should be used to send this message.
  32. * If no mailer is given it will first check if [[mailer]] is set and if not,
  33. * the "mailer" application component will be used instead.
  34. * @return bool whether this message is sent successfully.
  35. */
  36. public function send(MailerInterface $mailer = null)
  37. {
  38. if ($mailer === null && $this->mailer === null) {
  39. $mailer = Yii::$app->getMailer();
  40. } elseif ($mailer === null) {
  41. $mailer = $this->mailer;
  42. }
  43. return $mailer->send($this);
  44. }
  45. /**
  46. * PHP magic method that returns the string representation of this object.
  47. * @return string the string representation of this object.
  48. */
  49. public function __toString()
  50. {
  51. // __toString cannot throw exception
  52. // use trigger_error to bypass this limitation
  53. try {
  54. return $this->toString();
  55. } catch (\Exception $e) {
  56. ErrorHandler::convertExceptionToError($e);
  57. return '';
  58. }
  59. }
  60. }