Last active
October 21, 2019 06:08
-
-
Save wpo365/9aa568585d86f410ad1d40b07bab224c to your computer and use it in GitHub Desktop.
Requires a user to be signed into WordPress when accessing files e.g. in the wp-content directory. To configure authentication for designates directories, you must additionally configure .htaccess to create the proxy in the first place. See the 2nd file in this gist for an example. In this example, WordPress is installed in a subdirectory called…
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# BEGIN WordPress | |
<IfModule mod_rewrite.c> | |
RewriteEngine On | |
RewriteBase /wordpress/ | |
RewriteRule ^index\.php$ - [L] | |
# BEGIN THIS DL-FILE.PHP ADDITION | |
RewriteCond %{REQUEST_URI} ^.*wp-content/.* | |
RewriteRule ^wp-content/uploads/(.*)$ dl-file.php?file=$1 [QSA,L] | |
# END THIS DL-FILE.PHP ADDITION | |
RewriteCond %{REQUEST_FILENAME} !-f | |
RewriteCond %{REQUEST_FILENAME} !-d | |
RewriteRule . /wordpress/index.php [L] | |
</IfModule> | |
# END WordPress | |
Options -Indexes |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
/* | |
* dl-file.php | |
* | |
* Protect uploaded files with login. | |
* | |
* @link http://wordpress.stackexchange.com/questions/37144/protect-wordpress-uploads-if-user-is-not-logged-in | |
* @link https://gist.github.com/hakre/1552239 | |
* | |
* @author hakre <http://hakre.wordpress.com/> | |
* @license GPL-3.0+ | |
* @registry SPDX | |
*/ | |
require_once('wp-load.php'); | |
require_once ABSPATH . WPINC . '/formatting.php'; | |
require_once ABSPATH . WPINC . '/capabilities.php'; | |
require_once ABSPATH . WPINC . '/user.php'; | |
require_once ABSPATH . WPINC . '/meta.php'; | |
require_once ABSPATH . WPINC . '/post.php'; | |
require_once ABSPATH . WPINC . '/pluggable.php'; | |
wp_cookie_constants(); | |
is_user_logged_in() || auth_redirect(); | |
list( $basedir ) = array_values( array_intersect_key( wp_upload_dir(), array( 'basedir' => 1 ) ) ) + array( NULL ); | |
$file = rtrim( $basedir, '/' ). '/' . str_replace( '..', '', isset( $_GET[ 'file' ] ) ? $_GET[ 'file' ] : '' ); | |
if ( !$basedir || !is_file( $file ) ) { | |
status_header( 404 ); | |
die( '404 — File not found.' ); | |
} | |
$mime = wp_check_filetype( $file ); | |
if( false === $mime[ 'type' ] && function_exists( 'mime_content_type' ) ) | |
$mime[ 'type' ] = mime_content_type( $file ); | |
if( $mime[ 'type' ] ) | |
$mimetype = $mime[ 'type' ]; | |
else | |
$mimetype = 'image/' . substr( $file, strrpos( $file, '.' ) + 1 ); | |
header( 'Content-Type: ' . $mimetype ); // always send this | |
if ( false === strpos( $_SERVER[ 'SERVER_SOFTWARE' ], 'Microsoft-IIS' ) ) | |
header( 'Content-Length: ' . filesize( $file ) ); | |
$last_modified = gmdate( 'D, d M Y H:i:s', filemtime( $file ) ); | |
$etag = '"' . md5( $last_modified ) . '"'; | |
header( "Last-Modified: $last_modified GMT" ); | |
header( 'ETag: ' . $etag ); | |
header( 'Expires: ' . gmdate( 'D, d M Y H:i:s', time() + 100000000 ) . ' GMT' ); | |
// Support for Conditional GET | |
$client_etag = isset( $_SERVER[ 'HTTP_IF_NONE_MATCH' ] ) ? stripslashes( $_SERVER[ 'HTTP_IF_NONE_MATCH' ] ) : false; | |
if( ! isset( $_SERVER[ 'HTTP_IF_MODIFIED_SINCE' ] ) ) | |
$_SERVER[ 'HTTP_IF_MODIFIED_SINCE' ] = false; | |
$client_last_modified = trim( $_SERVER[ 'HTTP_IF_MODIFIED_SINCE' ] ); | |
// If string is empty, return 0. If not, attempt to parse into a timestamp | |
$client_modified_timestamp = $client_last_modified ? strtotime( $client_last_modified ) : 0; | |
// Make a timestamp for our most recent modification... | |
$modified_timestamp = strtotime( $last_modified ); | |
if ( ( $client_last_modified && $client_etag ) | |
? ( ( $client_modified_timestamp >= $modified_timestamp) && ( $client_etag == $etag ) ) | |
: ( ( $client_modified_timestamp >= $modified_timestamp) || ( $client_etag == $etag ) ) | |
) { | |
status_header( 304 ); | |
exit; | |
} | |
// If we made it this far, just serve the file | |
readfile( $file ); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment