2019-05-02 18:17:27 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2014-12-28 11:13:49 -05:00
|
|
|
class UserExport < ActiveRecord::Base
|
2018-06-04 21:41:40 -04:00
|
|
|
belongs_to :user
|
2019-04-03 04:01:19 -04:00
|
|
|
belongs_to :upload, dependent: :destroy
|
2014-12-24 04:11:41 -05:00
|
|
|
|
2019-05-21 04:02:36 -04:00
|
|
|
around_destroy :ignore_missing_post_uploads
|
|
|
|
|
|
|
|
def ignore_missing_post_uploads
|
|
|
|
post_ids = upload.post_uploads.pluck(:post_id)
|
|
|
|
yield
|
|
|
|
post_ids.each { |post_id| PostCustomField.create!(post_id: post_id, name: Post::MISSING_UPLOADS_IGNORED, value: "t") }
|
|
|
|
end
|
|
|
|
|
2014-12-24 04:11:41 -05:00
|
|
|
def self.remove_old_exports
|
2018-06-04 21:41:40 -04:00
|
|
|
UserExport.where('created_at < ?', 2.days.ago).find_each do |user_export|
|
|
|
|
user_export.destroy!
|
2014-12-24 04:11:41 -05: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-28 11:13:49 -05:00
|
|
|
# Table name: user_exports
|
2014-12-24 04:11:41 -05:00
|
|
|
#
|
2015-02-04 00:34:25 -05:00
|
|
|
# id :integer not null, primary key
|
2019-01-11 14:29:56 -05:00
|
|
|
# file_name :string not null
|
2015-02-04 00:34:25 -05:00
|
|
|
# user_id :integer not null
|
2019-01-11 14:29:56 -05:00
|
|
|
# created_at :datetime not null
|
|
|
|
# updated_at :datetime not null
|
2018-04-19 07:30:31 -04:00
|
|
|
# upload_id :integer
|
2014-12-24 04:11:41 -05:00
|
|
|
#
|