FEATURE: new rake task to clean up uploads & thumbnails

This commit is contained in:
Régis Hanol 2014-09-29 18:31:53 +02:00
parent 5d91a4ef0c
commit 652cc3efba
8 changed files with 76 additions and 39 deletions

View file

@ -84,7 +84,6 @@ class UserAvatarsController < ApplicationController
end end
end end
# this protects us from a DoS # this protects us from a DoS
def render_dot def render_dot
expires_in 10.minutes, public: true expires_in 10.minutes, public: true

View file

@ -8,9 +8,6 @@ module FileStore
def store_optimized_image(file, optimized_image) def store_optimized_image(file, optimized_image)
end end
def store_avatar(file, avatar, size)
end
def remove_upload(upload) def remove_upload(upload)
end end

View file

@ -14,11 +14,6 @@ module FileStore
store_file(file, path) store_file(file, path)
end end
def store_avatar(file, avatar, size)
path = get_path_for_avatar(file, avatar, size)
store_file(file, path)
end
def remove_upload(upload) def remove_upload(upload)
remove_file(upload.url) remove_file(upload.url)
end end
@ -80,10 +75,6 @@ module FileStore
"#{relative_base_url}/_optimized/#{optimized_image.sha1[0..2]}/#{optimized_image.sha1[3..5]}/#{filename}" "#{relative_base_url}/_optimized/#{optimized_image.sha1[0..2]}/#{optimized_image.sha1[3..5]}/#{filename}"
end end
def get_path_for_avatar(file, avatar, size)
relative_avatar_template(avatar).gsub("{size}", size.to_s)
end
def relative_avatar_template(avatar) def relative_avatar_template(avatar)
File.join( File.join(
relative_base_url, relative_base_url,

View file

@ -20,11 +20,6 @@ module FileStore
store_file(file, path) store_file(file, path)
end end
def store_avatar(file, avatar, size)
path = get_path_for_avatar(file, avatar, size)
store_file(file, path)
end
def remove_upload(upload) def remove_upload(upload)
remove_file(upload.url) remove_file(upload.url)
end end

View file

@ -23,7 +23,6 @@ class LetterAvatar
end end
end end
def cache_path def cache_path
"public/uploads/letter_avatars/#{VERSION}" "public/uploads/letter_avatars/#{VERSION}"
end end

View file

@ -77,3 +77,78 @@ task "uploads:migrate_from_s3" => :environment do
puts puts
end end
task "uploads:clean_up" => :environment do
RailsMultisite::ConnectionManagement.each_connection do |db|
puts "Cleaning up uploads and thumbnails for '#{db}'..."
if Discourse.store.external?
puts "This task only works for internal storages."
next
end
public_directory = "#{Rails.root}/public"
##
## DATABASE vs FILE SYSTEM
##
# uploads & avatars
Upload.order(:id).find_each do |upload|
path = "#{public_directory}#{upload.url}"
if !File.exists?(path)
upload.destroy rescue nil
putc "#"
else
putc "."
end
end
# optimized images
OptimizedImage.order(:id).find_each do |optimized_image|
path = "#{public_directory}#{optimized_image.url}"
if !File.exists?(path)
optimized_image.destroy rescue nil
putc "#"
else
putc "."
end
end
##
## FILE SYSTEM vs DATABASE
##
uploads_directory = "#{public_directory}/uploads/#{db}"
# avatars (no avatar should be stored in that old directory)
FileUtils.rm_rf("#{uploads_directory}/avatars") rescue nil
# uploads
Dir.glob("#{uploads_directory}/*/*.*").each do |f|
url = "/uploads/#{db}/" << f.split("/uploads/#{db}/")[1]
if !Upload.where(url: url).exists?
FileUtils.rm(f) rescue nil
putc "#"
else
putc "."
end
end
# optimized images
Dir.glob("#{uploads_directory}/_optimized/*/*/*.*").each do |f|
url = "/uploads/#{db}/_optimized/" << f.split("/uploads/#{db}/_optimized/")[1]
if !OptimizedImage.where(url: url).exists?
FileUtils.rm(f) rescue nil
putc "#"
else
putc "."
end
end
puts
end
end

View file

@ -9,6 +9,7 @@ describe FileStore::LocalStore do
let(:uploaded_file) { file_from_fixtures("logo.png") } let(:uploaded_file) { file_from_fixtures("logo.png") }
let(:optimized_image) { build(:optimized_image) } let(:optimized_image) { build(:optimized_image) }
let(:avatar) { build(:upload) } let(:avatar) { build(:upload) }
describe ".store_upload" do describe ".store_upload" do
@ -31,15 +32,6 @@ describe FileStore::LocalStore do
end end
describe ".store_avatar" do
it "returns a relative url" do
store.expects(:copy_file)
store.store_avatar({}, upload, 100).should == "/uploads/default/avatars/e9d/71f/5ee7c92d6d/100.png"
end
end
describe ".remove_upload" do describe ".remove_upload" do
it "does not delete non uploaded" do it "does not delete non uploaded" do

View file

@ -13,7 +13,6 @@ describe FileStore::S3Store do
let(:optimized_image_file) { file_from_fixtures("logo.png") } let(:optimized_image_file) { file_from_fixtures("logo.png") }
let(:avatar) { build(:upload) } let(:avatar) { build(:upload) }
let(:avatar_file) { file_from_fixtures("logo-dev.png") }
before(:each) do before(:each) do
SiteSetting.stubs(:s3_upload_bucket).returns("S3_Upload_Bucket") SiteSetting.stubs(:s3_upload_bucket).returns("S3_Upload_Bucket")
@ -42,16 +41,6 @@ describe FileStore::S3Store do
end end
describe ".store_avatar" do
it "returns an absolute schemaless url" do
avatar.stubs(:id).returns(42)
s3_helper.expects(:upload)
store.store_avatar(avatar_file, avatar, 100).should == "//s3_upload_bucket.s3.amazonaws.com/avatars/e9d71f5ee7c92d6dc9e92ffdad17b8bd49418f98/100.png"
end
end
describe ".remove_upload" do describe ".remove_upload" do
it "calls remove_file with the url" do it "calls remove_file with the url" do