mirror of
https://github.com/moodle/moodle.git
synced 2025-04-13 04:22:07 +02:00
Merge branch 'MDL-41846-master' of git://github.com/xow/moodle
This commit is contained in:
commit
c676a343a5
@ -46,7 +46,8 @@ class repository_url extends repository {
|
||||
public function __construct($repositoryid, $context = SYSCONTEXTID, $options = array()){
|
||||
global $CFG;
|
||||
parent::__construct($repositoryid, $context, $options);
|
||||
$this->file_url = optional_param('file', '', PARAM_URL);
|
||||
$this->file_url = optional_param('file', '', PARAM_RAW);
|
||||
$this->file_url = $this->escape_url($this->file_url);
|
||||
}
|
||||
|
||||
public function check_login() {
|
||||
@ -93,13 +94,17 @@ EOD;
|
||||
* @return array
|
||||
*/
|
||||
public function get_listing($path='', $page='') {
|
||||
global $CFG, $OUTPUT;
|
||||
$ret = array();
|
||||
$ret['list'] = array();
|
||||
$ret['nosearch'] = true;
|
||||
$ret['norefresh'] = true;
|
||||
$ret['nologin'] = true;
|
||||
|
||||
$this->file_url = clean_param($this->file_url, PARAM_URL);
|
||||
if (empty($this->file_url)) {
|
||||
throw new repository_exception('validfiletype', 'repository_url');
|
||||
}
|
||||
|
||||
$this->parse_file(null, $this->file_url, $ret, true);
|
||||
return $ret;
|
||||
}
|
||||
@ -217,6 +222,26 @@ EOD;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Escapes a url by replacing spaces with %20.
|
||||
*
|
||||
* Note: In general moodle does not automatically escape urls, but for the purposes of making this plugin more user friendly
|
||||
* and make it consistent with some other areas in moodle (such as mod_url), urls will automatically be escaped.
|
||||
*
|
||||
* If moodle_url or PARAM_URL is changed to clean characters that need to be escaped, then this function can be removed
|
||||
*
|
||||
* @param string $url An unescaped url.
|
||||
* @return string The escaped url
|
||||
*/
|
||||
protected function escape_url($url) {
|
||||
$url = str_replace('"', '%22', $url);
|
||||
$url = str_replace('\'', '%27', $url);
|
||||
$url = str_replace(' ', '%20', $url);
|
||||
$url = str_replace('<', '%3C', $url);
|
||||
$url = str_replace('>', '%3E', $url);
|
||||
return $url;
|
||||
}
|
||||
|
||||
public function supported_returntypes() {
|
||||
return (FILE_INTERNAL | FILE_EXTERNAL);
|
||||
}
|
||||
|
91
repository/url/tests/lib_test.php
Normal file
91
repository/url/tests/lib_test.php
Normal file
@ -0,0 +1,91 @@
|
||||
<?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/>.
|
||||
|
||||
/**
|
||||
* Unit tests for the URL repository.
|
||||
*
|
||||
* @package repository_url
|
||||
* @copyright 2014 John Okely
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*/
|
||||
|
||||
defined('MOODLE_INTERNAL') || die;
|
||||
|
||||
global $CFG;
|
||||
require_once($CFG->dirroot . '/repository/url/lib.php');
|
||||
|
||||
|
||||
/**
|
||||
* URL repository test case.
|
||||
*
|
||||
* @copyright 2014 John Okely
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*/
|
||||
class repository_url_lib_testcase extends advanced_testcase {
|
||||
|
||||
/**
|
||||
* Check that the url escaper performs as expected
|
||||
*/
|
||||
public function test_escape_url() {
|
||||
$this->resetAfterTest();
|
||||
|
||||
$repoid = $this->getDataGenerator()->create_repository('url')->id;
|
||||
|
||||
$conversions = array(
|
||||
'http://example.com/test_file.png' => 'http://example.com/test_file.png',
|
||||
'http://example.com/test%20file.png' => 'http://example.com/test%20file.png',
|
||||
'http://example.com/test file.png' => 'http://example.com/test%20file.png',
|
||||
'http://example.com/test file.png?query=string+test&more=string+tests' =>
|
||||
'http://example.com/test%20file.png?query=string+test&more=string+tests',
|
||||
'http://example.com/?tag=<p>' => 'http://example.com/?tag=%3Cp%3E',
|
||||
'http://example.com/"quoted".txt' => 'http://example.com/%22quoted%22.txt',
|
||||
'http://example.com/\'quoted\'.txt' => 'http://example.com/%27quoted%27.txt',
|
||||
'' => ''
|
||||
);
|
||||
|
||||
foreach ($conversions as $input => $expected) {
|
||||
// The constructor uses a optional_param, so we need to hack $_GET.
|
||||
$_GET['file'] = $input;
|
||||
$repository = new repository_url($repoid);
|
||||
$this->assertSame($expected, $repository->file_url);
|
||||
}
|
||||
|
||||
$exceptions = array(
|
||||
'%' => true,
|
||||
'!' => true,
|
||||
'!https://download.moodle.org/unittest/test.jpg' => true,
|
||||
'https://download.moodle.org/unittest/test.jpg' => false
|
||||
);
|
||||
|
||||
foreach ($exceptions as $input => $expected) {
|
||||
$caughtexception = false;
|
||||
try {
|
||||
// The constructor uses a optional_param, so we need to hack $_GET.
|
||||
$_GET['file'] = $input;
|
||||
$repository = new repository_url($repoid);
|
||||
$repository->get_listing();
|
||||
} catch (repository_exception $e) {
|
||||
if ($e->errorcode == 'validfiletype') {
|
||||
$caughtexception = true;
|
||||
}
|
||||
}
|
||||
$this->assertSame($expected, $caughtexception);
|
||||
}
|
||||
|
||||
unset($_GET['file']);
|
||||
}
|
||||
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user