case 'admin':
case 'calendar':
case 'mnet course':
- return "/course/$url";
+ if (strpos($url, '../') === 0) {
+ $url = ltrim($url, '.');
+ } else {
+ $url = "/course/$url";
+ }
break;
case 'user':
case 'blog':
- return "/$module/$url";
+ $url = "/$module/$url";
break;
case 'upload':
- return $url;
+ $url = $url;
break;
case 'coursetags':
- return '/'.$url;
+ $url = '/'.$url;
break;
case 'library':
case '':
- return '/';
+ $url = '/';
break;
case 'message':
- return "/message/$url";
+ $url = "/message/$url";
+ break;
+ case 'notes':
+ $url = "/notes/$url";
break;
default:
- return "/mod/$module/$url";
+ $url = "/mod/$module/$url";
break;
}
+
+ //now let's sanitise urls - there might be some ugly nasties:-(
+ $parts = explode('?', $url);
+ $script = array_shift($parts);
+ if (strpos($script, 'http') === 0) {
+ $script = clean_param($script, PARAM_URL);
+ } else {
+ $script = clean_param($script, PARAM_PATH);
+ }
+
+ $query = '';
+ if ($parts) {
+ $query = implode('', $parts);
+ $query = str_replace('&', '&', $query); // both & and & are stored in db :-|
+ $parts = explode('&', $query);
+ $eq = urlencode('=');
+ foreach ($parts as $key=>$part) {
+ $part = urlencode(urldecode($part));
+ $part = str_replace($eq, '=', $part);
+ $parts[$key] = $part;
+ }
+ $query = '?'.implode('&', $parts);
+ }
+
+ return $script.$query;
}
$tl=textlib_get_instance();
$brokenurl=($tl->strlen($log->url)==100 && $tl->substr($log->url,97)=='...');
- $log->url = strip_tags(urldecode($log->url)); // Some XSS protection
- $log->info = strip_tags(urldecode($log->info)); // Some XSS protection
- $log->url = s($log->url); /// XSS protection and XHTML compatibility - should be in link_to_popup_window() instead!!
-
echo '<tr class="r'.$row.'">';
if ($course->id == SITEID) {
echo "<td class=\"cell c0\">\n";
//Filter log->info
$log->info = format_string($log->info);
- $log->url = strip_tags(urldecode($log->url)); // Some XSS protection
- $log->info = strip_tags(urldecode($log->info)); // Some XSS protection
- $log->url = str_replace('&', '&', $log->url); /// XHTML compatibility
-
echo '<tr class="r'.$row.'">';
if ($course->id == SITEID) {
echo "<td class=\"r$row c0\" >\n";
//Filter log->info
$log->info = format_string($log->info);
-
- $log->url = strip_tags(urldecode($log->url)); // Some XSS protection
$log->info = strip_tags(urldecode($log->info)); // Some XSS protection
- $log->url = str_replace('&', '&', $log->url); // XHTML compatibility
$firstField = $courses[$log->course];
$fullname = fullname($log, has_capability('moodle/site:viewfullnames', get_context_instance(CONTEXT_COURSE, $course->id)));