Skip to content

Commit

Permalink
MDL-33158 fixed bugs with restricting file typs in filepicker
Browse files Browse the repository at this point in the history
- extension was returned without leading dot which resulted in improper validation
- fixed human-readable mime type in error message
- fixed youtube repository to support video files and pass filetype validation
  • Loading branch information
marinaglancy committed May 22, 2012
1 parent ca9875d commit e563582
Show file tree
Hide file tree
Showing 4 changed files with 20 additions and 18 deletions.
12 changes: 6 additions & 6 deletions lib/filelib.php
Original file line number Diff line number Diff line change
Expand Up @@ -1595,22 +1595,22 @@ function mimeinfo_from_type($element, $mimetype) {
foreach($mimeinfo as $filetype => $values) {
if ($values['type'] == $mimetype) {
if ($cached[$mimetype] === null) {
$cached[$mimetype] = $filetype;
$cached[$mimetype] = '.'.$filetype;
}
if (!empty($values['defaulticon'])) {
$cached[$mimetype] = $filetype;
$cached[$mimetype] = '.'.$filetype;
break;
}
}
}
if (empty($cached[$mimetype])) {
$cached[$mimetype] = 'xxx';
$cached[$mimetype] = '.xxx';
}
}
if ($element === 'extension') {
return $cached[$mimetype];
} else {
return mimeinfo($element, '.'.$cached[$mimetype]);
return mimeinfo($element, $cached[$mimetype]);
}
}

Expand Down Expand Up @@ -1831,7 +1831,7 @@ function file_get_typegroup($element, $groups) {
$mimeinfo = & get_mimetypes_array();
$cached[$element][$group] = array();
foreach ($mimeinfo as $extension => $value) {
$value['extension'] = $extension;
$value['extension'] = '.'.$extension;
if (empty($value[$element])) {
continue;
}
Expand Down Expand Up @@ -1859,7 +1859,7 @@ function file_get_typegroup($element, $groups) {
*/
function file_extension_in_typegroup($filename, $groups, $checktype = false) {
$extension = pathinfo($filename, PATHINFO_EXTENSION);
if (!empty($extension) && in_array(strtolower($extension), file_get_typegroup('extension', $groups))) {
if (!empty($extension) && in_array('.'.strtolower($extension), file_get_typegroup('extension', $groups))) {
return true;
}
return $checktype && file_mimetype_in_typegroup(mimeinfo('type', $filename), $groups);
Expand Down
5 changes: 2 additions & 3 deletions repository/lib.php
Original file line number Diff line number Diff line change
Expand Up @@ -1728,9 +1728,8 @@ public function filter(&$value) {
or (is_array($accepted_types) and in_array('*', $accepted_types))) {
return true;
} else {
$extensions = file_get_typegroup('extension', $accepted_types);
foreach ($extensions as $ext) {
if (preg_match('#\.'.$ext.'$#i', $value['title'])) {
foreach ($accepted_types as $ext) {
if (preg_match('#'.$ext.'$#i', $value['title'])) {
return true;
}
}
Expand Down
5 changes: 1 addition & 4 deletions repository/upload/lib.php
Original file line number Diff line number Diff line change
Expand Up @@ -173,10 +173,7 @@ public function process_upload($saveas_filename, $maxbytes, $types = '*', $savep
// check filetype
$filemimetype = mimeinfo('type', $_FILES[$elname]['name']);
if (!in_array($filemimetype, $this->mimetypes)) {
if ($sm->string_exists($filemimetype, 'mimetypes')) {
$filemimetype = get_string($filemimetype, 'mimetypes');
}
throw new moodle_exception('invalidfiletype', 'repository', '', $filemimetype);
throw new moodle_exception('invalidfiletype', 'repository', '', get_mimetype_description(array('filename' => $_FILES[$elname]['name'])));
}
}

Expand Down
16 changes: 11 additions & 5 deletions repository/youtube/lib.php
Original file line number Diff line number Diff line change
Expand Up @@ -111,17 +111,23 @@ private function _get_collection($keyword, $start, $max, $sort) {
$links = $xml->children('http://www.w3.org/2005/Atom');
foreach ($xml->entry as $entry) {
$media = $entry->children('http://search.yahoo.com/mrss/');
$title = $media->group->title;
$title = (string)$media->group->title;
$description = (string)$media->group->description;
if (empty($description)) {
$description = $title;
}
$attrs = $media->group->thumbnail[2]->attributes();
$thumbnail = $attrs['url'];
$arr = explode('/', $entry->id);
$id = $arr[count($arr)-1];
$source = 'http://www.youtube.com/v/' . $id . '#' . $title;
$list[] = array(
'title'=>(string)$title,
'shorttitle'=>$title,
'thumbnail_title'=>$description,
'title'=>$title.'.avi', // this is a hack so we accept this file by extension
'thumbnail'=>(string)$attrs['url'],
'thumbnail_width'=>150,
'thumbnail_height'=>120,
'thumbnail_width'=>(int)$attrs['width'],
'thumbnail_height'=>(int)$attrs['height'],
'size'=>'',
'date'=>'',
'source'=>$source
Expand Down Expand Up @@ -186,7 +192,7 @@ public function print_login($ajax = true) {
* @return array
*/
public function supported_filetypes() {
return array('web_video');
return array('video');
}

/**
Expand Down

0 comments on commit e563582

Please sign in to comment.