Make attachment file path relative to the upload dir. Don't use GUID to find attachement URL. Props DD32. see #7622
git-svn-id: http://svn.automattic.com/wordpress/trunk@8796 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
e819a98d94
commit
9b02e29a7b
|
@ -93,6 +93,13 @@ function wp_generate_attachment_metadata( $attachment_id, $file ) {
|
||||||
$metadata['height'] = $imagesize[1];
|
$metadata['height'] = $imagesize[1];
|
||||||
list($uwidth, $uheight) = wp_shrink_dimensions($metadata['width'], $metadata['height']);
|
list($uwidth, $uheight) = wp_shrink_dimensions($metadata['width'], $metadata['height']);
|
||||||
$metadata['hwstring_small'] = "height='$uheight' width='$uwidth'";
|
$metadata['hwstring_small'] = "height='$uheight' width='$uwidth'";
|
||||||
|
// Make the file path relative to the upload dir
|
||||||
|
if ( ($uploads = wp_upload_dir()) && false === $uploads['error'] ) { // Get upload directory
|
||||||
|
if ( 0 === strpos($file, $uploads['basedir']) ) {// Check that the upload base exists in the file path
|
||||||
|
$file = str_replace($uploads['basedir'], '', $file); // Remove upload dir from the file path
|
||||||
|
$file = ltrim($file, '/');
|
||||||
|
}
|
||||||
|
}
|
||||||
$metadata['file'] = $file;
|
$metadata['file'] = $file;
|
||||||
|
|
||||||
// make thumbnails and other intermediate sizes
|
// make thumbnails and other intermediate sizes
|
||||||
|
|
|
@ -27,6 +27,12 @@
|
||||||
*/
|
*/
|
||||||
function get_attached_file( $attachment_id, $unfiltered = false ) {
|
function get_attached_file( $attachment_id, $unfiltered = false ) {
|
||||||
$file = get_post_meta( $attachment_id, '_wp_attached_file', true );
|
$file = get_post_meta( $attachment_id, '_wp_attached_file', true );
|
||||||
|
// If the file is relative, prepend upload dir
|
||||||
|
if ( 0 !== strpos($file, '/') ) {
|
||||||
|
$uploads = wp_upload_dir();
|
||||||
|
$file = $uploads['basedir'] . "/$file";
|
||||||
|
}
|
||||||
|
|
||||||
if ( $unfiltered )
|
if ( $unfiltered )
|
||||||
return $file;
|
return $file;
|
||||||
return apply_filters( 'get_attached_file', $file, $attachment_id );
|
return apply_filters( 'get_attached_file', $file, $attachment_id );
|
||||||
|
@ -51,6 +57,14 @@ function update_attached_file( $attachment_id, $file ) {
|
||||||
|
|
||||||
$file = apply_filters( 'update_attached_file', $file, $attachment_id );
|
$file = apply_filters( 'update_attached_file', $file, $attachment_id );
|
||||||
|
|
||||||
|
// Make the file path relative to the upload dir
|
||||||
|
if ( ($uploads = wp_upload_dir()) && false === $uploads['error'] ) { // Get upload directory
|
||||||
|
if ( 0 === strpos($file, $uploads['basedir']) ) {// Check that the upload base exists in the file path
|
||||||
|
$file = str_replace($uploads['basedir'], '', $file); // Remove upload dir from the file path
|
||||||
|
$file = ltrim($file, '/');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return update_post_meta( $attachment_id, '_wp_attached_file', $file );
|
return update_post_meta( $attachment_id, '_wp_attached_file', $file );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2450,9 +2464,18 @@ function wp_get_attachment_url( $post_id = 0 ) {
|
||||||
if ( !$post =& get_post( $post_id ) )
|
if ( !$post =& get_post( $post_id ) )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
$url = '';
|
||||||
|
if ( $file = get_post_meta( $post->ID, '_wp_attached_file', true) ) { //Get attached file
|
||||||
|
if ( ($uploads = wp_upload_dir()) && false === $uploads['error'] ) { //Get upload directory
|
||||||
|
if ( 0 === strpos($file, $uploads['basedir']) ) //Check that the upload base exists in the file location
|
||||||
|
$url = str_replace($uploads['basedir'], $uploads['baseurl'], $file); //replace file location with url location
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( empty($url) ) //If any of the above options failed, Fallback on the GUID as used pre-2.7, not recomended to rely upon this.
|
||||||
$url = get_the_guid( $post->ID );
|
$url = get_the_guid( $post->ID );
|
||||||
|
|
||||||
if ( 'attachment' != $post->post_type || !$url )
|
if ( 'attachment' != $post->post_type || empty($url) )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return apply_filters( 'wp_get_attachment_url', $url, $post->ID );
|
return apply_filters( 'wp_get_attachment_url', $url, $post->ID );
|
||||||
|
|
Loading…
Reference in New Issue