Use wp_get_mime_types() when calling wp_check_filetype() in the audio and video shortcodes. fixes #24911.

git-svn-id: https://develop.svn.wordpress.org/trunk@24944 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Andrew Nacin 2013-08-01 13:33:15 +00:00
parent 40477d88a4
commit eedc483e37

View File

@ -870,7 +870,7 @@ function wp_audio_shortcode( $attr ) {
$primary = false; $primary = false;
if ( ! empty( $src ) ) { if ( ! empty( $src ) ) {
$type = wp_check_filetype( $src ); $type = wp_check_filetype( $src, wp_get_mime_types() );
if ( ! in_array( $type['ext'], $default_types ) ) if ( ! in_array( $type['ext'], $default_types ) )
return sprintf( '<a class="wp-embedded-audio" href="%s">%s</a>', esc_url( $src ), esc_html( $src ) ); return sprintf( '<a class="wp-embedded-audio" href="%s">%s</a>', esc_url( $src ), esc_html( $src ) );
$primary = true; $primary = true;
@ -878,7 +878,7 @@ function wp_audio_shortcode( $attr ) {
} else { } else {
foreach ( $default_types as $ext ) { foreach ( $default_types as $ext ) {
if ( ! empty( $$ext ) ) { if ( ! empty( $$ext ) ) {
$type = wp_check_filetype( $$ext ); $type = wp_check_filetype( $$ext, wp_get_mime_types() );
if ( $type['ext'] === $ext ) if ( $type['ext'] === $ext )
$primary = true; $primary = true;
} }
@ -934,7 +934,7 @@ function wp_audio_shortcode( $attr ) {
if ( ! empty( $$fallback ) ) { if ( ! empty( $$fallback ) ) {
if ( empty( $fileurl ) ) if ( empty( $fileurl ) )
$fileurl = $$fallback; $fileurl = $$fallback;
$type = wp_check_filetype( $$fallback ); $type = wp_check_filetype( $$fallback, wp_get_mime_types() );
$html .= sprintf( $source, $type['type'], esc_url( $$fallback ) ); $html .= sprintf( $source, $type['type'], esc_url( $$fallback ) );
} }
} }
@ -1008,7 +1008,7 @@ function wp_video_shortcode( $attr ) {
$primary = false; $primary = false;
if ( ! empty( $src ) ) { if ( ! empty( $src ) ) {
$type = wp_check_filetype( $src ); $type = wp_check_filetype( $src, wp_get_mime_types() );
if ( ! in_array( $type['ext'], $default_types ) ) if ( ! in_array( $type['ext'], $default_types ) )
return sprintf( '<a class="wp-embedded-video" href="%s">%s</a>', esc_url( $src ), esc_html( $src ) ); return sprintf( '<a class="wp-embedded-video" href="%s">%s</a>', esc_url( $src ), esc_html( $src ) );
$primary = true; $primary = true;
@ -1016,7 +1016,7 @@ function wp_video_shortcode( $attr ) {
} else { } else {
foreach ( $default_types as $ext ) { foreach ( $default_types as $ext ) {
if ( ! empty( $$ext ) ) { if ( ! empty( $$ext ) ) {
$type = wp_check_filetype( $$ext ); $type = wp_check_filetype( $$ext, wp_get_mime_types() );
if ( $type['ext'] === $ext ) if ( $type['ext'] === $ext )
$primary = true; $primary = true;
} }
@ -1075,7 +1075,7 @@ function wp_video_shortcode( $attr ) {
if ( ! empty( $$fallback ) ) { if ( ! empty( $$fallback ) ) {
if ( empty( $fileurl ) ) if ( empty( $fileurl ) )
$fileurl = $$fallback; $fileurl = $$fallback;
$type = wp_check_filetype( $$fallback ); $type = wp_check_filetype( $$fallback, wp_get_mime_types() );
// m4v sometimes shows up as video/mpeg which collides with mp4 // m4v sometimes shows up as video/mpeg which collides with mp4
if ( 'm4v' === $type['ext'] ) if ( 'm4v' === $type['ext'] )
$type['type'] = 'video/m4v'; $type['type'] = 'video/m4v';