. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Http\RequestHandlers; use Fisharebest\Webtrees\Http\Exceptions\HttpBadRequestException; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Registry; use Fisharebest\Webtrees\Services\MediaFileService; use Fisharebest\Webtrees\Validator; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; /** * Download a media file. */ class AdminMediaFileDownload implements RequestHandlerInterface { private MediaFileService $media_file_service; /** * @param MediaFileService $media_file_service */ public function __construct(MediaFileService $media_file_service) { $this->media_file_service = $media_file_service; } /** * Download a non-image media file. * * @param ServerRequestInterface $request * * @return ResponseInterface */ public function handle(ServerRequestInterface $request): ResponseInterface { $filesystem = Registry::filesystem()->data(); $path = Validator::queryParams($request)->string('path'); $media_folders = $this->media_file_service->allMediaFolders($filesystem)->all(); foreach ($media_folders as $media_folder) { if (str_starts_with($path, $media_folder)) { return Registry::imageFactory()->fileResponse($filesystem, $path, false); } } throw new HttpBadRequestException(I18N::translate('The parameter “path” is invalid.')); } }