Upload dir cleanups. Honor old fileupload_path settings if present.

git-svn-id: http://svn.automattic.com/wordpress/trunk@3389 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
ryan 2006-01-02 04:33:27 +00:00
parent 807f5ded08
commit c798fede84
1 changed files with 52 additions and 33 deletions

View File

@ -851,48 +851,67 @@ function get_attached_file($attachment_id) {
return get_post_meta($attachment_id, '_wp_attached_file', true); return get_post_meta($attachment_id, '_wp_attached_file', true);
} }
function wp_mkdir_p($target) {
// from php.net/mkdir user contributed notes
if (file_exists($target)) {
if (! @ is_dir($target))
return false;
else
return true;
}
// Attempting to create the directory may clutter up our display.
if (@ mkdir($target)) {
$stat = @ stat(dirname($target));
$dir_perms = $stat['mode'] & 0007777; // Get the permission bits.
@ chmod($target, $dir_perms);
return true;
} else {
if ( is_dir(dirname($target)) )
return false;
}
// If the above failed, attempt to create the parent node, then try again.
if (wp_mkdir_p(dirname($target)))
return wp_mkdir_p($target);
return false;
}
// Returns an array containing the current upload directory's path and url, or an error message. // Returns an array containing the current upload directory's path and url, or an error message.
function wp_upload_dir() { function wp_upload_dir() {
if ( defined('UPLOADS') ) $dir = trim(get_settings('fileupload_realpath'));
$dir = UPLOADS; $url = trim(get_settings('fileupload_url'));
else
$dir = 'wp-content/uploads';
$path = ABSPATH . $dir; $custom = true;
if ( empty($dir) || empty($url) ) {
// Give the new dirs the same perms as wp-content. $dir = ABSPATH . 'wp-content/uploads';
$stat = stat(ABSPATH . 'wp-content'); $url = get_option('siteurl') . '/wp-content/uploads';
$dir_perms = $stat['mode'] & 0007777; // Get the permission bits. $custom = false;
// Make sure we have an uploads dir
if ( ! file_exists( $path ) ) {
if ( ! @ mkdir( $path ) )
return array('error' => "Unable to create directory $path. Is its parent directory writable by the server?");
@ chmod( $path, $dir_perms );
} }
// Generate the yearly and monthly dirs if ( defined('UPLOADS') ) {
$time = current_time( 'mysql' ); $dir = ABSPATH . UPLOADS;
$y = substr( $time, 0, 4 ); $url = get_option('siteurl') . '/' . UPLOADS;
$m = substr( $time, 5, 2 ); $custom = false;
$pathy = "$path/$y";
$pathym = "$path/$y/$m";
// Make sure we have a yearly dir
if ( ! file_exists( $pathy ) ) {
if ( ! @ mkdir( $pathy ) )
return array('error' => "Unable to create directory $pathy. Is $path writable?");
@ chmod( $pathy, $dir_perms );
} }
// Make sure we have a monthly dir if ( ! $custom) {
if ( ! file_exists( $pathym ) ) { // Generate the yearly and monthly dirs
if ( ! @ mkdir( $pathym ) ) $time = current_time( 'mysql' );
return array('error' => "Unable to create directory $pathym. Is $pathy writable?"); $y = substr( $time, 0, 4 );
@ chmod( $pathym, $dir_perms ); $m = substr( $time, 5, 2 );
$dir = $dir . "/$y/$m";
$url = $url . "/$y/$m";
} }
$uploads = array('path' => $pathym, 'url' => get_option('siteurl') . "/$dir/$y/$m", 'error' => false); // Make sure we have an uploads dir
if ( ! wp_mkdir_p( $dir ) ) {
$message = sprintf(__('Unable to create directory %s. Is its parent directory writable by the server?'), $dir);
return array('error' => $message);
}
$uploads = array('path' => $dir, 'url' => $url, 'error' => false);
return apply_filters('upload_dir', $uploads); return apply_filters('upload_dir', $uploads);
} }