mirror of
https://github.com/discourse/discourse.git
synced 2025-05-23 06:51:27 +08:00
FEATURE: Add support for secure media (#7888)
This PR introduces a new secure media setting. When enabled, it prevent unathorized access to media uploads (files of type image, video and audio). When the `login_required` setting is enabled, then all media uploads will be protected from unauthorized (anonymous) access. When `login_required`is disabled, only media in private messages will be protected from unauthorized access. A few notes: - the `prevent_anons_from_downloading_files` setting no longer applies to audio and video uploads - the `secure_media` setting can only be enabled if S3 uploads are already enabled and configured - upload records have a new column, `secure`, which is a boolean `true/false` of the upload's secure status - when creating a public post with an upload that has already been uploaded and is marked as secure, the post creator will raise an error - when enabling or disabling the setting on a site with existing uploads, the rake task `uploads:ensure_correct_acl` should be used to update all uploads' secure status and their ACL on S3
This commit is contained in:

committed by
Martin Brennan

parent
56b19ba740
commit
102909edb3
@ -1,8 +1,6 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
def print_status_with_label(label, current, max)
|
||||
print "\r%s%9d / %d (%5.1f%%)" % [label, current, max, ((current.to_f / max.to_f) * 100).round(1)]
|
||||
end
|
||||
require_dependency "rake_helpers"
|
||||
|
||||
def close_old_topics(category)
|
||||
topics = Topic.where(closed: false, category_id: category.id)
|
||||
@ -23,7 +21,7 @@ def close_old_topics(category)
|
||||
|
||||
topics.find_each do |topic|
|
||||
topic.update_status("closed", true, Discourse.system_user)
|
||||
print_status_with_label(" closing old topics: ", topics_closed += 1, total)
|
||||
RakeHelpers.print_status_with_label(" closing old topics: ", topics_closed += 1, total)
|
||||
end
|
||||
end
|
||||
|
||||
@ -49,7 +47,7 @@ def apply_auto_close(category)
|
||||
|
||||
topics.find_each do |topic|
|
||||
topic.inherit_auto_close_from_category
|
||||
print_status_with_label(" applying auto-close to topics: ", topics_closed += 1, total)
|
||||
RakeHelpers.print_status_with_label(" applying auto-close to topics: ", topics_closed += 1, total)
|
||||
end
|
||||
end
|
||||
|
||||
@ -77,7 +75,7 @@ task "topics:watch_all_replied_topics" => :environment do
|
||||
t.topic_users.where(posted: true).find_each do |tp|
|
||||
tp.update!(notification_level: TopicUser.notification_levels[:watching], notifications_reason_id: TopicUser.notification_reasons[:created_post])
|
||||
end
|
||||
print_status(count += 1, total)
|
||||
RakeHelpers.print_status(count += 1, total)
|
||||
end
|
||||
|
||||
puts "", "Done"
|
||||
@ -96,12 +94,8 @@ task "topics:update_fancy_titles" => :environment do
|
||||
|
||||
Topic.find_each do |topic|
|
||||
topic.fancy_title
|
||||
print_status(count += 1, total)
|
||||
RakeHelpers.print_status(count += 1, total)
|
||||
end
|
||||
|
||||
puts "", "Done"
|
||||
end
|
||||
|
||||
def print_status(current, max)
|
||||
print "\r%9d / %d (%5.1f%%)" % [current, max, ((current.to_f / max.to_f) * 100).round(1)]
|
||||
end
|
||||
|
Reference in New Issue
Block a user