2014-12-29 00:13:49 +08:00
|
|
|
class UserExport < ActiveRecord::Base
|
2014-12-24 17:11:41 +08:00
|
|
|
|
|
|
|
def self.get_download_path(filename)
|
2014-12-29 00:13:49 +08:00
|
|
|
path = File.join(UserExport.base_directory, filename)
|
2016-05-26 04:20:35 +08:00
|
|
|
File.exists?(path) ? path : nil
|
2014-12-24 17:11:41 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
def self.remove_old_exports
|
2016-05-26 04:20:35 +08:00
|
|
|
UserExport.where('created_at < ?', 2.days.ago).find_each do |expired_export|
|
2015-01-16 01:30:59 +08:00
|
|
|
file_name = "#{expired_export.file_name}-#{expired_export.id}.csv.gz"
|
2014-12-29 00:13:49 +08:00
|
|
|
file_path = "#{UserExport.base_directory}/#{file_name}"
|
|
|
|
|
2016-05-26 04:20:35 +08:00
|
|
|
File.delete(file_path) if File.exist?(file_path)
|
|
|
|
expired_export.destroy
|
2014-12-24 17:11:41 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.base_directory
|
|
|
|
File.join(Rails.root, "public", "uploads", "csv_exports", RailsMultisite::ConnectionManagement.current_db)
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
# == Schema Information
|
|
|
|
#
|
2014-12-29 00:13:49 +08:00
|
|
|
# Table name: user_exports
|
2014-12-24 17:11:41 +08:00
|
|
|
#
|
2015-02-04 13:34:25 +08:00
|
|
|
# id :integer not null, primary key
|
2017-12-05 23:29:14 +08:00
|
|
|
# file_name :string(255) not null
|
2015-02-04 13:34:25 +08:00
|
|
|
# user_id :integer not null
|
2017-12-05 23:29:14 +08:00
|
|
|
# created_at :datetime
|
|
|
|
# updated_at :datetime
|
2014-12-24 17:11:41 +08:00
|
|
|
#
|