32 lines
		
	
	
		
			740 B
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			32 lines
		
	
	
		
			740 B
		
	
	
	
		
			PHP
		
	
	
	
<?php
 | 
						|
 | 
						|
namespace BookStack\Theming;
 | 
						|
 | 
						|
use BookStack\Facades\Theme;
 | 
						|
use BookStack\Http\Controller;
 | 
						|
use BookStack\Util\FilePathNormalizer;
 | 
						|
 | 
						|
class ThemeController extends Controller
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * Serve a public file from the configured theme.
 | 
						|
     */
 | 
						|
    public function publicFile(string $theme, string $path)
 | 
						|
    {
 | 
						|
        $cleanPath = FilePathNormalizer::normalize($path);
 | 
						|
        if ($theme !== Theme::getTheme() || !$cleanPath) {
 | 
						|
            abort(404);
 | 
						|
        }
 | 
						|
 | 
						|
        $filePath = theme_path("public/{$cleanPath}");
 | 
						|
        if (!file_exists($filePath)) {
 | 
						|
            abort(404);
 | 
						|
        }
 | 
						|
 | 
						|
        $response = $this->download()->streamedFileInline($filePath);
 | 
						|
        $response->setMaxAge(86400);
 | 
						|
 | 
						|
        return $response;
 | 
						|
    }
 | 
						|
}
 |