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_course\route\shim;

use core\param;
use core\router\route;
use core\router\route_controller;
use core\router\schema\parameters\query_parameter;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface;

/**
 * A shim for the course routes.
 *
 * @package    core_course
 * @copyright  Andrew Lyons <andrew@nicols.co.uk>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
final class course_routes {
    use route_controller;

    /**
     * Shim /course/admin.php to the course management controller.
     *
     * @param ServerRequestInterface $request
     * @param ResponseInterface $response
     * @return ResponseInterface
     */
    #[route(
        path: '/admin.php',
        queryparams: [
            new query_parameter(
                name: 'courseid',
                type: param::INT,
                description: 'The course ID',
                required: true,
            ),
        ],
    )]
    public function administer_course(
        ServerRequestInterface $request,
        ResponseInterface $response,
    ): ResponseInterface {
        $params = $request->getQueryParams();
        return self::redirect_to_callable(
            $request,
            $response,
            [\core_course\route\controller\course_management::class, 'administer_course'],
            pathparams: $params + ['course' => $params['courseid']],
            excludeparams: ['courseid'],
        );
    }

    /**
     * Shim /course/tags.php to the course tag management controller.
     *
     * @param ServerRequestInterface $request
     * @param ResponseInterface $response
     * @return ResponseInterface
     */
    #[route(
        path: '/tags.php',
        queryparams: [
            new query_parameter(
                name: 'id',
                type: param::INT,
                description: 'The course ID',
                required: true,
            ),
            new query_parameter(
                name: 'returnurl',
                type: param::LOCALURL,
                description: 'The return URL',
                required: false,
            ),
        ],
    )]
    public function administer_tags(
        ServerRequestInterface $request,
        ResponseInterface $response,
    ): ResponseInterface {
        $params = $request->getQueryParams();
        return self::redirect_to_callable(
            $request,
            $response,
            [\core_course\route\controller\tags_controller::class, 'administer_tags'],
            pathparams: $params + ['course' => $params['id']],
            excludeparams: ['id'],
        );
    }
}