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/>.

/**
 * Mailpit mail handling implementation.
 *
 * @package    core
 * @category   test
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 * @copyright  Simey Lameze <simey@moodle.com>
 */
namespace core\test;

use core\http_client;
use stdClass;

/**
 * Mailpit email handling class.
 *
 * @package    core
 * @category   test
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class mailpit_email_catcher implements email_catcher {

    /** @var http_client The http client object. */
    protected http_client $httpclient;

    /**
     * Constructor.
     *
     * @param string $baseuri The base uri for the mailpit server.
     */
    public function __construct(string $baseuri) {
        $this->httpclient = new http_client(['base_uri' => $baseuri]);
    }

    /**
     * Reset the mailpit server after a test.
     */
    public function reset_after_test(): void {
        $this->httpclient->delete_all();
    }

    /**
     * Delete all messages from the mailpit server.
     */
    public function delete_all() {
        $this->httpclient->delete('api/v1/messages');
    }

    /**
     * Get a list of messages from the mailpit server.
     *
     * @param bool $showdetails Optional. Whether to include detailed information in the messages. Default is false.
     * @return iterable
     */
    public function get_messages(bool $showdetails = false): iterable {
        $uri = 'api/v1/messages';
        $options = [
            'query' => [
                'start' => 0,
            ],
        ];

        do {
            $response = $this->httpclient->get(
                uri: $uri,
                options: $options,
            );

            $data = json_decode($response->getBody());
            foreach ($data->messages as $messagedata) {
                yield mailpit_message::create_from_api_response($this, $messagedata, $showdetails);
            }

            $options['query']['start'] = $data->start + $data->count;
        } while ($data->total > ($options['query']['start']));
    }

    /**
     * Get the message summary for a specific message.
     *
     * @param string $id The message id.
     * @return stdClass
     */
    public function get_message_data(string $id): stdClass {
        $response = $this->httpclient->get("api/v1/message/{$id}");

        return json_decode($response->getBody());
    }

    /**
     * Search for a message in the mailpit server.
     *
     * @param string $query The search query.
     * @return mixed
     */
    public function search(string $query): iterable {
        $uri = "api/v1/search?query={$query}";

        $response = $this->httpclient->get($uri);
        $data = json_decode($response->getBody());

        foreach ($data->messages as $messagedata) {
            yield mailpit_message::create_from_api_response($this, $messagedata);
        }
    }
}