FileDownloadController::download() assumes any scheme that is not private should have public cache control settings

Created on 30 May 2019, over 5 years ago
Updated 18 January 2023, almost 2 years ago

FileDownloadController::download() assumes any file scheme that is not private should have public cache control headers applied. This poses a potential security issue with file schemes provided by contrib modules such as flysystem_s3 where a private AWS S3 bucket is setup and used to store private and sensitive files. A developer may be unaware that sensitive files are being cached because the Cache-Control header of the file is being set to Public. I have marked this issue Critical as a result of this scenario.

Even if an implementation of hook_file_download sets a Cachce-Control header to private, if the $scheme is not private \Symfony\Component\HttpFoundation\BinaryFileResponse::__construct will remove this header beacuse the $public is set to TRUE.

Should there be a method on \Drupal\Core\StreamWrapper\StreamWrapperInterface to determine if a file scheme is considered to be public and use that method to set the $public parameter on the BinaryFileResponse constructor accordingly?

Thoughts?

https://www.drupal.org/project/drupal/issues/2148353 appears to be addressing file access issues but doesn't appear to be addressing this issue specifically.

🐛 Bug report
Status

Active

Version

10.1

Component
File system 

Last updated 3 days ago

Created by

🇨🇦Canada tame4tex

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • Status changed to Active almost 2 years ago
Production build 0.71.5 2024