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\router\schema\objects;

use core\param;
use core\router\schema\example;
use core\router\schema\referenced_object;
use core\router\schema\specification;

/**
 * A standard response for user preferences.
 *
 * @package    core
 * @copyright  2023 Andrew Lyons <andrew@nicols.co.uk>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class stacktrace extends type_base implements referenced_object {
    /** @var array The stacks in the trace */
    protected array $content;

    /**
     * Constructor for a new stacktrace object.
     */
    public function __construct() {
        $this->content = [
            'file' => new scalar_type(param::PATH),
            'line' => new scalar_type(param::INT),
            'function' => new scalar_type(param::RAW),
            'args' => new array_of_things(),
            'class' => new scalar_type(param::RAW),
            'type' => new scalar_type(param::RAW),
        ];

        $pathroot = '/Users/example/Sites/moodle';
        parent::__construct(
            examples: [
                new example(
                    name: 'A sample stacktrace',
                    value: [
                        [
                            "file" => "{$pathroot}/lib/classes/router/schema/objects/array_of_strings.php",
                            "line" => 48,
                            "function" => "validate_param",
                            "args" => [
                                "string",
                                "int",
                                false,
                                "The value 'string' was not of type string.",
                            ],
                        ],
                        [
                            "file" => "{$pathroot}/lib/classes/router/schema/objects/schema_object.php",
                            "line" => 85,
                            "function" => "validate_data",
                            "class" => "core\\router\\schema\\objects\\array_of_strings",
                            "type" => "->",
                            "args" => [
                                [
                                    "additionalProp1" => "string",
                                    "additionalProp2" => "string",
                                    "additionalProp3" => "string",
                                ],
                            ],
                        ],
                        [
                            "file" => "{$pathroot}/lib/classes/router/route.php",
                            "line" => 264,
                            "function" => "validate_data",
                            "class" => "core\\router\\schema\\objects\\schema_object",
                            "type" => "->",
                            "args" => [
                                [
                                    "preferences" => [
                                        "additionalProp1" => "string",
                                        "additionalProp2" => "string",
                                        "additionalProp3" => "string",
                                    ],
                                ],
                            ],
                        ],
                    ],
                ),
            ],
        );
    }

    #[\Override]
    public function get_openapi_description(
        specification $api,
        ?string $path = null,
    ): ?\stdClass {
        $additionalproperties = new \stdClass();

        foreach ($this->content as $name => $content) {
            $additionalproperties->{$name} = $content->get_openapi_description($api, $path);
        }

        $data = parent::get_openapi_description($api, $path);
        $data->type = 'array';
        $data->items = (object) [
            'type' => 'object',
            'properties' => $additionalproperties,
        ];

        return $data;
    }

    #[\Override]
    public function validate_data($data) {
        // Do not validate the data at all.
        // Stacktraces tend to be used with exceptions and we want whatever was passed through to come out.
        return $data;
    }
}