FIX: Don't secure the about banner image (#29889)

Uploads that are linked to site settings shouldn't be flagged as secure in login-required sites that enable secure uploads. However, in order for site setting uploads to not be marked secured, the frontend uploader has to include 2 params in the upload request: `for_site_setting: true` and `type: "site_setting"`.

Since these 2 params are semantically identical, we want the `type: "site_setting"` param alone to make the upload correctly treated as a site setting upload. To achieve that, we need to include the `site_setting` type in the public types list because the `for_site_setting` param has the same effect — it marks the upload as a public type.

b138eaf9e5/lib/upload_security.rb (L128-L131)
This commit is contained in:
Osama Sayegh 2024-11-25 11:12:00 +03:00 committed by GitHub
parent 0c68b14534
commit eaa3f813c1
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 21 additions and 0 deletions

View File

@ -37,6 +37,7 @@ class UploadSecurity
category_background category_background
group_flair group_flair
badge_image badge_image
site_setting
] ]
PUBLIC_UPLOAD_REFERENCE_TYPES = %w[ PUBLIC_UPLOAD_REFERENCE_TYPES = %w[

View File

@ -139,6 +139,26 @@ describe "Admin About Config Area Page", type: :system do
expect(config_area.general_settings_section).to have_saved_successfully expect(config_area.general_settings_section).to have_saved_successfully
expect(SiteSetting.about_banner_image).to eq(nil) expect(SiteSetting.about_banner_image).to eq(nil)
end end
context "when login_required is true" do
before { SiteSetting.login_required = true }
it "doesn't mark the banner image upload as secure" do
setup_or_skip_s3_system_test(enable_secure_uploads: true)
config_area.visit
image_file = file_from_fixtures("logo.png", "images")
config_area.general_settings_section.banner_image_uploader.select_image(image_file.path)
expect(config_area.general_settings_section.banner_image_uploader).to have_uploaded_image
config_area.general_settings_section.submit
expect(config_area.general_settings_section).to have_saved_successfully
expect(SiteSetting.about_banner_image.secure).to eq(false)
end
end
end end
end end