2017-03-30 10:42:33 -07:00
|
|
|
# frozen_string_literal: true
|
2017-05-01 17:14:47 -07:00
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: imports
|
|
|
|
#
|
2018-04-23 02:29:17 -07:00
|
|
|
# id :bigint(8) not null, primary key
|
2017-05-01 17:14:47 -07:00
|
|
|
# type :integer not null
|
2017-07-12 18:12:25 -07:00
|
|
|
# approved :boolean default(FALSE), not null
|
2017-05-01 17:14:47 -07:00
|
|
|
# created_at :datetime not null
|
|
|
|
# updated_at :datetime not null
|
|
|
|
# data_file_name :string
|
|
|
|
# data_content_type :string
|
|
|
|
# data_file_size :integer
|
|
|
|
# data_updated_at :datetime
|
2018-04-23 02:29:17 -07:00
|
|
|
# account_id :bigint(8) not null
|
2019-02-02 18:59:51 -08:00
|
|
|
# overwrite :boolean default(FALSE), not null
|
2017-05-01 17:14:47 -07:00
|
|
|
#
|
2017-03-30 10:42:33 -07:00
|
|
|
|
|
|
|
class Import < ApplicationRecord
|
2020-05-24 00:15:23 -07:00
|
|
|
FILE_TYPES = %w(text/plain text/csv application/csv).freeze
|
2019-02-02 18:59:51 -08:00
|
|
|
MODES = %i(merge overwrite).freeze
|
2017-04-16 07:28:26 -07:00
|
|
|
|
2017-03-30 10:42:33 -07:00
|
|
|
self.inheritance_column = false
|
|
|
|
|
2018-01-19 11:56:47 -08:00
|
|
|
belongs_to :account
|
2017-03-30 10:42:33 -07:00
|
|
|
|
2020-11-19 08:48:13 -08:00
|
|
|
enum type: [:following, :blocking, :muting, :domain_blocking, :bookmarks]
|
2017-03-30 10:42:33 -07:00
|
|
|
|
2017-04-16 07:28:26 -07:00
|
|
|
validates :type, presence: true
|
2020-12-18 00:18:31 -08:00
|
|
|
validates_with ImportValidator, on: :create
|
2017-03-30 10:42:33 -07:00
|
|
|
|
2018-02-25 16:31:44 -08:00
|
|
|
has_attached_file :data
|
2017-03-30 10:42:33 -07:00
|
|
|
validates_attachment_content_type :data, content_type: FILE_TYPES
|
2017-09-02 11:45:42 -07:00
|
|
|
validates_attachment_presence :data
|
2019-02-02 18:59:51 -08:00
|
|
|
|
|
|
|
def mode
|
|
|
|
overwrite? ? :overwrite : :merge
|
|
|
|
end
|
|
|
|
|
|
|
|
def mode=(str)
|
|
|
|
self.overwrite = str.to_sym == :overwrite
|
|
|
|
end
|
2017-03-30 10:42:33 -07:00
|
|
|
end
|