trabajo-afectivo/app/models/store/file.rb

137 lines
3.2 KiB
Ruby
Raw Normal View History

# Copyright (C) 2012-2021 Zammad Foundation, http://zammad-foundation.org/
class Store < ApplicationModel
2015-04-27 21:44:41 +00:00
class File < ApplicationModel
include ApplicationLib
after_destroy :destroy_provider
2015-07-26 21:35:56 +00:00
=begin
2015-07-26 21:21:51 +00:00
add new file to store
store_file_id = Store::File.add(binary_data)
2015-07-26 21:21:51 +00:00
do also verify of written data
store_file_id = Store::File.add(binary_data, true)
2015-07-26 21:21:51 +00:00
=end
def self.add(data, verify = true)
2016-02-02 12:50:49 +00:00
sha = Digest::SHA256.hexdigest(data)
2016-02-02 12:50:49 +00:00
file = Store::File.find_by(sha: sha)
if file.nil?
2015-04-27 21:44:41 +00:00
# load backend based on config
adapter_name = Setting.get('storage_provider') || 'DB'
if !adapter_name
2016-03-01 14:26:46 +00:00
raise 'Missing storage_provider setting option'
2015-04-27 21:44:41 +00:00
end
adapter = "Store::Provider::#{adapter_name}".constantize
2016-02-02 12:50:49 +00:00
adapter.add(data, sha)
2015-04-27 21:44:41 +00:00
file = Store::File.create(
provider: adapter_name,
sha: sha,
2015-04-27 21:44:41 +00:00
)
# verify
if verify
read_data = adapter.get(sha)
read_sha = Digest::SHA256.hexdigest(read_data)
if sha != read_sha
2016-03-01 14:26:46 +00:00
raise "Content not written correctly (provider #{adapter_name})."
end
end
end
2015-04-27 21:44:41 +00:00
file
end
2015-07-26 21:21:51 +00:00
=begin
read content of a file
store = Store::File.find(123)
2015-07-26 21:21:51 +00:00
store.content # returns binary
2015-07-26 21:21:51 +00:00
=end
2015-04-27 21:44:41 +00:00
def content
"Store::Provider::#{provider}".constantize.get(sha)
2014-05-03 19:02:38 +00:00
end
2015-07-26 21:21:51 +00:00
=begin
file system check of store, check data and sha (in case fix it)
Store::File.verify
2015-07-26 21:21:51 +00:00
read each file which should be in backend and verify against sha hash
2015-07-26 21:21:51 +00:00
in case of fixing sha hash use:
Store::File.verify(true)
2015-07-26 21:21:51 +00:00
=end
2015-04-27 21:44:41 +00:00
def self.verify(fix_it = nil)
success = true
Store::File.find_each(batch_size: 10) do |item|
sha = Digest::SHA256.hexdigest(item.content)
2016-02-02 12:50:49 +00:00
logger.info "CHECK: Store::File.find(#{item.id})"
next if sha == item.sha
success = false
2016-02-02 12:50:49 +00:00
logger.error "DIFF: sha diff of Store::File.find(#{item.id}) current:#{sha}/db:#{item.sha}/provider:#{item.provider}"
store = Store.find_by(store_file_id: item.id)
2016-02-02 12:50:49 +00:00
logger.error "STORE: #{store.inspect}"
item.update_attribute(:sha, sha) if fix_it # rubocop:disable Rails/SkipsModelValidations
end
2015-04-27 21:44:41 +00:00
success
end
2015-07-26 21:21:51 +00:00
=begin
move file from one to other provider
move files from file backend to db
Store::File.move('File', 'DB')
move files from db backend to fs
Store::File.move('DB', 'File')
2017-03-06 11:18:04 +00:00
nice move to keep system responsive
Store::File.move('DB', 'File', delay_in_sec) # e. g. 1
2015-07-26 21:21:51 +00:00
=end
2017-03-06 11:18:04 +00:00
def self.move(source, target, delay = nil)
adapter_source = "Store::Provider::#{source}".constantize
adapter_target = "Store::Provider::#{target}".constantize
Store::File.where(provider: source).find_each(batch_size: 10) do |item|
adapter_target.add(item.content, item.sha)
2017-11-23 08:09:44 +00:00
item.update_attribute(:provider, target) # rubocop:disable Rails/SkipsModelValidations
2016-02-02 12:50:49 +00:00
adapter_source.delete(item.sha)
2015-05-05 08:11:31 +00:00
logger.info "Moved file #{item.sha} from #{source} to #{target}"
2017-03-06 11:18:04 +00:00
sleep delay if delay
end
2015-04-27 21:44:41 +00:00
true
end
2015-04-27 21:44:41 +00:00
private
2015-04-27 21:44:41 +00:00
def destroy_provider
"Store::Provider::#{provider}".constantize.delete(sha)
2015-04-27 21:44:41 +00:00
end
end
end