require 'pathname' require 'smart_proxy_openscap/storage' require 'smart_proxy_openscap/storage_fs_common' module Proxy::OpenSCAP class StorageFs < Storage include StorageFsCommon def store_archive(data) store(data, StoreReportError) end def store_spool(data) store(data, StoreSpoolError) end def store_failed(data) store(data, StoreFailedError) end def store_corrupted(data) store(data, StoreCorruptedError) end def move_corrupted(digest, spooldir) source = "#{spooldir}/#{@namespace}/#{@cname}/#{@id}/#{@date}" move "#{source}/#{digest}", StoreCorruptedError end def get_arf_xml(digest) get_arf_file(digest)[:xml] end def delete_arf_file path = "#{@path_to_dir}/#{@namespace}/#{@cname}/#{@id}" raise FileNotFound, "Can't find path #{path}" if !File.directory?(path) || File.zero?(path) FileUtils.rm_r path {:id => @id, :deleted => true}.to_json end def get_arf_file(digest) file = File.open(get_path digest) { :size => File.size(file), :xml => file.read } end def get_path(digest) full_path = @path + digest raise FileNotFound, "Can't find path #{full_path}" if !File.file?(full_path) || File.zero?(full_path) full_path end def spool_errors path = "#{@path_to_dir}/#{@namespace}" { :errors_count => File.exists?(path) ? list_dirs(path).count : 0 } end def list_dirs(path) Pathname.new(path).children.select(&:directory?) end private def store_file(path_to_store, data) filename = Digest::SHA256.hexdigest data target_path = path_to_store + filename File.open(target_path,'w') { |f| f.write(data) } target_path end def create_directory begin FileUtils.mkdir_p @path rescue StandardError => e logger.error "Could not create '#{@path}' directory: #{e.message}" raise e end @path end def move(source, error_type) begin create_directory FileUtils.mv source, @path rescue StandardError => e raise error_type, "Could not move file: #{e.message}" end end def store(data, error_type) begin create_directory rescue StandardError => e raise error_type, "Could not fulfill request: #{e.message}" end begin target_path = store_file(@path, data) rescue StandardError => e raise error_type, "Could not store file: #{e.message}" end logger.debug "File #{target_path} stored in reports dir." end end end