Proyectos de Subversion Moodle

Rev

Autoría | Ultima modificación | Ver Log |

<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.

namespace core\test;

use stdClass;

/**
 * Mailpit message handling implementation.
 *
 * @package    core
 * @category   test
 * @copyright  Simey Lameze <simey@moodle.com>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class mailpit_message implements message {

    /** @var bool Whether the message has been loaded. */
    protected bool $messageloaded = false;

    /**
     * Constructor.
     *
     * @param email_catcher $client The email catcher client.
     * @param string $id The message ID.
     * @param stdClass $sender The sender.
     * @param string $subject The subject.
     * @param array $recipients The recipients.
     * @param array $cc The cc recipients.
     * @param array $bcc The bcc recipients.
     * @param int $attachmentcount The number of attachments.
     * @param string|null $text The text body.
     * @param string|null $html The HTML body.
     * @param array $attachments The attachments.
     * @param array $inline The inline attachments.
     */
    protected function __construct(
        /** @var email_catcher $client The email catcher client used for message operations.*/
        private readonly email_catcher $client,
        /** @var string $id The unique identifier for the message. */
        private readonly string $id,
        /** @var stdClass $sender The sender of the message, represented as an object with email details. */
        private readonly stdClass $sender,
        /** @var string $subject The subject line of the message. */
        private readonly string $subject,
        /** @var array $recipients List of primary recipients for the message. */
        private readonly array $recipients,
        /** @var array $cc List of carbon copy recipients (optional, defaults to an empty array). */
        private readonly array $cc = [],
        /** @var array $bcc List of blind carbon copy recipients (optional, defaults to an empty array). */
        private readonly array $bcc = [],
        /** @var int $attachmentcount The number of attachments in the message (default is 0). */
        private readonly int $attachmentcount = 0,
        /** @var ?string $text The plain text body of the message (nullable, might be loaded later). */
        private ?string $text = null,
        /** @var ?string $html The HTML body of the message (nullable, might be loaded later). */
        private ?string $html = null,
        /** @var array $attachments An array of attachment details (defaults to empty array). */
        private array $attachments = [],
        /** @var array $inline An array of inline elements like images or styles (defaults to empty array). */
        private array $inline = [],
    ) {
    }

    /**
     * Load the message content.
     */
    protected function load_message_content(): void {
        if (!$this->messageloaded) {
            $message = $this->client->get_message_data($this->id);
            $this->text = $message->Text;
            $this->html = $message->HTML;
            $this->attachments = $message->Attachments;
            $this->inline = $message->Inline;
            $this->messageloaded = true;
        }
    }

    /**
     * Create a message from an api response.
     *
     * @param email_catcher $client The email catcher client.
     * @param stdClass $message The api response.
     * @param bool $showdetails Optional. Whether to include detailed information in the messages. Default is false.
     * @return mailpit_message The created mailpit message instance.
     */
    public static function create_from_api_response(
        email_catcher $client,
        stdClass $message,
        bool $showdetails = false,
    ): self {
        $message = new self(
            client: $client,
            id: $message->ID,
            sender: $message->From,
            subject: $message->Subject,
            recipients: $message->To,
            cc: $message->Cc,
            attachmentcount: $message->Attachments,
        );

        if ($showdetails) {
            $message->load_message_content();
        }

        return $message;
    }

    /**
     * Get the text representation of the body, if one was provided.
     *
     * @return null|string The text body.
     */
    public function get_body_text(): ?string {
        return $this->text;
    }

    /**
     * Get the HTML representation of the body, if one was provided.
     *
     * @return null|string The HTML body.
     */
    public function get_body_html(): ?string {
        return $this->html;
    }

    /**
     * Get the message ID.
     *
     * @return string The ID.
     */
    public function get_id(): string {
        return $this->id;
    }

    /**
     * Get the message recipients.
     *
     * @return iterable The recipients.
     */
    public function get_recipients(): iterable {
        foreach ($this->recipients as $user) {
            yield mailpit_message_user::from_recipient($user);
        }
    }

    /**
     * Get the first recipient of the message.
     *
     * @return string The email address of the first recipient.
     */
    public function get_first_recipient(): string {
        $recipients = $this->get_recipients();
        foreach ($recipients as $recipient) {
            return $recipient->get_address();
        }
        return '';
    }

    /**
     * Whether the message has the specified recipient.
     *
     * @param string $email The email address.
     * @return bool Whether the message has the recipient.
     */
    public function has_recipient(string $email): bool {
        foreach ($this->get_recipients() as $recipient) {
            if ($recipient->get_address() === $email) {
                return true;
            }
        }
        return false;
    }

    /**
     * Get the message cc recipients.
     *
     * @return iterable The cc recipients.
     */
    public function get_cc(): iterable {
        foreach ($this->cc as $user) {
            yield mailpit_message_user::from_recipient($user);
        }
    }

    /**
     * Get the message bcc recipients.
     *
     * @return iterable The bcc recipients.
     */
    public function get_bcc(): iterable {
        foreach ($this->bcc as $user) {
            yield mailpit_message_user::from_recipient($user);
        }
    }

    /**
     * Get the message subject.
     *
     * @return string The subject.
     */
    public function get_subject(): string {
        return $this->subject;
    }

    /**
     * Get the message sender.
     *
     * @return message_user The sender.
     */
    public function get_sender(): message_user {
        return mailpit_message_user::from_sender($this->sender);
    }
}