scinote-web/app/models/repository_asset_value.rb

96 lines
2.9 KiB
Ruby
Raw Normal View History

2019-07-26 21:58:51 +08:00
# frozen_string_literal: true
2018-03-10 00:04:54 +08:00
class RepositoryAssetValue < ApplicationRecord
belongs_to :created_by,
foreign_key: :created_by_id,
class_name: 'User',
optional: true
belongs_to :last_modified_by,
foreign_key: :last_modified_by_id,
class_name: 'User',
optional: true
belongs_to :asset,
inverse_of: :repository_asset_value,
dependent: :destroy
has_one :repository_cell, as: :value, dependent: :destroy, inverse_of: :value
accepts_nested_attributes_for :repository_cell
validates :asset, :repository_cell, presence: true
SORTABLE_COLUMN_NAME = 'active_storage_blobs.filename'
EXTRA_SORTABLE_VALUE_INCLUDE = { asset: { file_attachment: :blob } }.freeze
EXTRA_PRELOAD_INCLUDE = { asset: { file_attachment: :blob } }.freeze
2018-03-10 00:04:54 +08:00
def formatted
asset.file_name
2018-03-10 00:04:54 +08:00
end
def self.add_filter_condition(repository_rows, filter_element)
case filter_element.operator
when 'file_contains'
repository_rows.joins(repository_asset_values: { asset: :asset_text_datum })
.where('asset_text_data.data_vector @@ to_tsquery(?)',
"%#{sanitize_sql_like(filter_element.parameters['text'])}%")
when 'file_attached'
repository_rows.where.not(repository_asset_values: nil)
else
raise ArgumentError, 'Wrong operator for RepositoryAssetValue!'
end
end
def data
asset.file_name
end
def data_changed?(_new_data)
true
end
def update_data!(new_data, user)
2019-12-10 20:11:50 +08:00
if new_data.is_a?(String) # assume it's a signed_id_token
2019-12-10 15:41:09 +08:00
asset.file.attach(new_data)
2019-12-10 20:11:50 +08:00
elsif new_data[:file_data]
asset.file.attach(io: StringIO.new(Base64.decode64(new_data[:file_data])), filename: new_data[:file_name])
end
asset.last_modified_by = user
self.last_modified_by = user
asset.save! && save!
end
def snapshot!(cell_snapshot)
value_snapshot = dup
asset_snapshot = asset.dup
asset_snapshot.save!
# ActiveStorage::Blob is immutable, so we can just attach it to the new snapshot
asset_snapshot.file.attach(asset.blob)
value_snapshot.assign_attributes(
repository_cell: cell_snapshot,
asset: asset_snapshot,
created_at: created_at,
updated_at: updated_at
)
value_snapshot.save!
end
def self.new_with_payload(payload, attributes)
value = new(attributes)
team = value.repository_cell.repository_column.repository.team
value.asset = Asset.create!(created_by: value.created_by, last_modified_by: value.created_by, team: team)
2019-12-10 20:11:50 +08:00
if payload.is_a?(String) # assume it's a signed_id_token
2019-12-10 15:41:09 +08:00
value.asset.file.attach(payload)
2019-12-10 20:11:50 +08:00
elsif payload[:file_data]
value.asset.file.attach(io: StringIO.new(Base64.decode64(payload[:file_data])), filename: payload[:file_name])
end
value.asset.post_process_file(team)
value
end
2020-01-10 16:29:20 +08:00
alias export_formatted formatted
2018-03-10 00:04:54 +08:00
end