- 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
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]);
}
}
$mimeinfo = & get_mimetypes_array();
$cached[$element][$group] = array();
foreach ($mimeinfo as $extension => $value) {
- $value['extension'] = $extension;
+ $value['extension'] = '.'.$extension;
if (empty($value[$element])) {
continue;
}
*/
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);
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;
}
}
// 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'])));
}
}
$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
* @return array
*/
public function supported_filetypes() {
- return array('web_video');
+ return array('video');
}
/**