mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 18:12:46 +08:00
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:
parent
0c68b14534
commit
eaa3f813c1
|
@ -37,6 +37,7 @@ class UploadSecurity
|
|||
category_background
|
||||
group_flair
|
||||
badge_image
|
||||
site_setting
|
||||
]
|
||||
|
||||
PUBLIC_UPLOAD_REFERENCE_TYPES = %w[
|
||||
|
|
|
@ -139,6 +139,26 @@ describe "Admin About Config Area Page", type: :system do
|
|||
expect(config_area.general_settings_section).to have_saved_successfully
|
||||
expect(SiteSetting.about_banner_image).to eq(nil)
|
||||
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
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user