mirror of
https://github.com/moodle/moodle.git
synced 2025-01-17 21:49:15 +01:00
d05c2ac7cc
A thank you to Nelson Cheng for find this issue and suggesting a patch.
88 lines
2.5 KiB
PHP
88 lines
2.5 KiB
PHP
<?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/>.
|
|
|
|
/**
|
|
* Callback for equella repository.
|
|
*
|
|
* @since Moodle 2.3
|
|
* @package repository_equella
|
|
* @copyright 2012 Dongsheng Cai {@link http://dongsheng.org}
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
require(__DIR__.'/../../config.php');
|
|
$json = required_param('tlelinks', PARAM_RAW);
|
|
|
|
require_login();
|
|
|
|
$decodedinfo = json_decode($json);
|
|
$info = array_pop($decodedinfo);
|
|
|
|
$url = '';
|
|
if (isset($info->url)) {
|
|
$url = s(clean_param($info->url, PARAM_URL));
|
|
}
|
|
|
|
$filename = '';
|
|
// Use $info->filename if exists, $info->name is a display name,
|
|
// it may not have extension
|
|
if (isset($info->filename)) {
|
|
$filename = s(clean_param($info->filename, PARAM_FILE));
|
|
} else if (isset($info->name)) {
|
|
$filename = s(clean_param($info->name, PARAM_FILE));
|
|
}
|
|
|
|
$thumbnail = '';
|
|
if (isset($info->thumbnail)) {
|
|
$thumbnail = s(clean_param($info->thumbnail, PARAM_URL));
|
|
}
|
|
|
|
$author = '';
|
|
if (isset($info->owner)) {
|
|
$author = s(clean_param($info->owner, PARAM_NOTAGS));
|
|
}
|
|
|
|
$license = '';
|
|
if (isset($info->license)) {
|
|
$license = s(clean_param($info->license, PARAM_ALPHAEXT));
|
|
}
|
|
|
|
$source = base64_encode(json_encode(array('url'=>$url,'filename'=>$filename)));
|
|
$sourcekey = sha1($source . repository::get_secret_key() . sesskey());
|
|
|
|
$js =<<<EOD
|
|
<html>
|
|
<head>
|
|
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
|
|
<script type="text/javascript">
|
|
window.onload = function() {
|
|
var resource = {};
|
|
resource.title = "$filename";
|
|
resource.source = "$source";
|
|
resource.sourcekey = "$sourcekey";
|
|
resource.thumbnail = '$thumbnail';
|
|
resource.author = "$author";
|
|
resource.license = "$license";
|
|
parent.M.core_filepicker.select_file(resource);
|
|
}
|
|
</script>
|
|
</head>
|
|
<body><noscript></noscript></body>
|
|
</html>
|
|
EOD;
|
|
|
|
header('Content-Type: text/html; charset=utf-8');
|
|
die($js);
|