Inti dari pertanyaannya adalah, saya mencari solusi seperti ini:
$blog_upload_dir_info = wp_upload_dir( $date, $blog_ID );
$blog_upload_url = $blog_upload_dir_info[ 'baseurl' ];
Di mana $blog_ID
berbeda dengan ID blog saat ini. Solusi «WP-paling jelas« gagal:
switch_to_blog( $blog_ID );
$blog_upload_dir_info = wp_upload_dir();
restore_current_blog();
sebagai wp_upload_dir () bergantung pada konstanta WP_CONTENT_URL
yang secara dinamis mengatur URL blog saat ini kecuali jika opsi upload_url_path
disetel.
Tentu saja, saya dapat mengatur opsi ini, tetapi ini akan memasangkan kode saya ke pengaturan sistem konkret yang mencakup banyak »WTF?« - potensial.
Jadi saya memutuskan untuk menambahkan opsi ini secara virtual:
/**
* Apply a value to the option blog_upload_url
* if there's not already one
*
* @wp-hook option_upload_url_path
* @param string $upload_url
* @return string
*/
function get_real_blog_upload_url( $upload_url ) {
if ( '' !== trim( $upload_url ) )
return $upload_url;
$upload_path = trim( get_option( 'upload_path' ) );
$siteurl = get_option( 'siteurl' );
$wp_content_dir = $siteurl . '/wp-content';
if ( empty( $upload_path ) || 'wp-content/uploads' == $upload_path ) {
$dir = $wp_content_dir . '/uploads';
} elseif ( 0 !== strpos( $upload_path, ABSPATH ) ) {
// $dir is absolute, $upload_path is (maybe) relative to ABSPATH
$dir = path_join( ABSPATH, $upload_path );
} else {
$dir = $upload_path;
}
if ( empty( $upload_path ) || ( 'wp-content/uploads' == $upload_path ) || ( $upload_path == $dir ) )
$upload_path = $wp_content_dir . '/uploads';
else
$upload_path = trailingslashit( $siteurl ) . $upload_path;
return $upload_path;
}
yang notabene sebagian bercabang wp_upload_dir()
dan karenanya bergantung pada konstanta yang sama sekali bukan praktik yang baik . Selain itu, garpu selalu digabungkan dengan implementasi asli dan jika perubahan asli, kita juga harus memperbaiki garpu.
Jadi karena solusi ini jauh dari sempurna, saya bertanya-tanya apakah ada cara yang lebih baik untuk mendapatkan URL unggah dengan ID blog.