discourse/lib/tasks/topics.rake
Penar Musaraj 102909edb3 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
2019-11-18 11:25:42 +10:00

102 lines
2.6 KiB
Ruby

# frozen_string_literal: true
require_dependency "rake_helpers"
def close_old_topics(category)
topics = Topic.where(closed: false, category_id: category.id)
if category.auto_close_based_on_last_post
topics = topics.where('last_posted_at < ?', category.auto_close_hours.hours.ago)
else
topics = topics.where('created_at < ?', category.auto_close_hours.hours.ago)
end
topics_closed = 0
total = topics.count
if total == 0
print " all old topics are closed"
return
end
topics.find_each do |topic|
topic.update_status("closed", true, Discourse.system_user)
RakeHelpers.print_status_with_label(" closing old topics: ", topics_closed += 1, total)
end
end
def apply_auto_close(category)
topics = Topic.where(closed: false, category_id: category.id)
.where(<<-SQL, TopicTimer.types[:close])
NOT EXISTS (
SELECT 1
FROM topic_timers
WHERE topic_timers.topic_id = topics.id
AND topic_timers.status_type = ?
AND topic_timers.deleted_at IS NULL
)
SQL
topics_closed = 0
total = topics.count
if total == 0
print " all topics have auto-close applied"
return
end
topics.find_each do |topic|
topic.inherit_auto_close_from_category
RakeHelpers.print_status_with_label(" applying auto-close to topics: ", topics_closed += 1, total)
end
end
task "topics:apply_autoclose" => :environment do
categories = Category.where("auto_close_hours > 0")
categories.find_each do |category|
puts "", "Applying auto-close to category '#{category.name}' ..."
close_old_topics(category)
puts ""
apply_auto_close(category)
puts ""
end
puts "", "Done"
end
task "topics:watch_all_replied_topics" => :environment do
puts "Setting all topics to Watching on which a user has posted at least once..."
topics = Topic.where("archetype != ?", Archetype.private_message)
total = topics.count
count = 0
topics.find_each do |t|
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
RakeHelpers.print_status(count += 1, total)
end
puts "", "Done"
end
task "topics:update_fancy_titles" => :environment do
if !SiteSetting.title_fancy_entities?
puts "fancy topic titles are disabled"
return
end
DB.exec("UPDATE topics SET fancy_title = NULL")
total = Topic.count
count = 0
Topic.find_each do |topic|
topic.fancy_title
RakeHelpers.print_status(count += 1, total)
end
puts "", "Done"
end