| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- <?php
- if (!isset($_GET['f']) ||
- !isset($_GET['t'])) {
- header('HTTP/1.1 400 Bad Request');
- die();
- }
- require('../constants.php');
- /**
- * Check if a file can be served by ext.php. A valid file is under a
- * EXTENSIONS_PATH/extension_name/static/ directory.
- *
- * You should sanitize path by using the realpath() function.
- *
- * @param $path the path to the file we want to serve.
- * @return true if it can be served, false else.
- *
- */
- function is_valid_path($path) {
- // It must be under the extension path.
- $in_ext_path = (substr($path, 0, strlen(EXTENSIONS_PATH)) === EXTENSIONS_PATH);
- if (!$in_ext_path) {
- return false;
- }
- // File to serve must be under a `ext_dir/static/` directory.
- $path_relative_to_ext = substr($path, strlen(EXTENSIONS_PATH) + 1);
- $path_splitted = explode('/', $path_relative_to_ext);
- if (count($path_splitted) < 3 || $path_splitted[1] !== 'static') {
- return false;
- }
- return true;
- }
- $file_name = urldecode($_GET['f']);
- $file_type = $_GET['t'];
- $absolute_filename = realpath(EXTENSIONS_PATH . '/' . $file_name);
- if (!is_valid_path($absolute_filename)) {
- header('HTTP/1.1 400 Bad Request');
- die();
- }
- switch ($file_type) {
- case 'css':
- header('Content-Type: text/css; charset=UTF-8');
- header('Content-Disposition: inline; filename="' . $file_name . '"');
- break;
- case 'js':
- header('Content-Type: application/javascript; charset=UTF-8');
- header('Content-Disposition: inline; filename="' . $file_name . '"');
- break;
- default:
- header('HTTP/1.1 400 Bad Request');
- die();
- }
- $mtime = @filemtime($absolute_filename);
- if ($mtime === false) {
- header('HTTP/1.1 404 Not Found');
- die();
- }
- require(LIB_PATH . '/http-conditional.php');
- if (!httpConditional($mtime, 604800, 2)) {
- readfile($absolute_filename);
- }
|