# encoding: utf-8 # # Redmine plugin for Document Management System "Features" # # Copyright © 2011-19 Karel Pičman # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; either version 2 # of the License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. class MigrateDocuments < ActiveRecord::Migration[4.2] def up # Migrate all documents from dmsf/p_{project identifier} to dmsf/{year}/{month} DmsfFileRevision.find_each do |dmsf_file_revision| if dmsf_file_revision.dmsf_file if dmsf_file_revision.dmsf_file.project origin = disk_file(dmsf_file_revision) if origin if File.exist?(origin) target = dmsf_file_revision.disk_file(false) if target if !File.exist?(target) begin FileUtils.mv origin, target, :verbose => true folder = storage_base_path(dmsf_file_revision) Dir.rmdir(folder) if (folder && (Dir.entries(folder).size == 2)) rescue => e msg = "DmsfFileRevisions ID #{dmsf_file_revision.id}: #{e.message}" say msg Rails.logger.error msg end else msg = "DmsfFileRevisions ID #{dmsf_file_revision.id}: Target '#{target}' exists" say msg Rails.logger.error msg end else msg = "DmsfFileRevisions ID #{dmsf_file_revision.id}: target = nil" say msg Rails.logger.error msg end else msg = "DmsfFileRevisions ID #{dmsf_file_revision.id}: Origin '#{origin}' doesn't exist" say msg Rails.logger.error msg end else msg = "DmsfFileRevisions ID #{dmsf_file_revision.id}: disk_file = nil" say msg Rails.logger.error msg end else msg = "DmsfFile ID #{dmsf_file_revision.dmsf_file.id}: project = nil" say msg Rails.logger.error msg end else msg = "DmsfFileRevisions ID #{dmsf_file_revision.id}: dmsf_file = nil" say msg Rails.logger.error msg end end end def down # Migrate all documents from dmsf/{year}/{month} to dmsf/p_{project identifier} DmsfFileRevision.find_each do |dmsf_file_revision| if dmsf_file_revision.dmsf_file if dmsf_file_revision.dmsf_file.project origin = dmsf_file_revision.disk_file(false) if origin if File.exist?(origin) target = disk_file(dmsf_file_revision) if target if File.exist?(target) msg = "DmsfFileRevisions ID #{dmsf_file_revision.id}: Target '#{target}' exists" say msg Rails.logger.error msg else begin FileUtils.mv origin, target, :verbose => true folder = dmsf_file_revision.storage_base_path Dir.rmdir(folder) if (folder && (Dir.entries(folder).size == 2)) rescue => e msg = "DmsfFileRevisions ID #{dmsf_file_revision.id}: #{e.message}" say msg Rails.logger.error msg end end else msg = "DmsfFileRevisions ID #{dmsf_file_revision.id}: target = nil" say msg Rails.logger.error msg end else msg = "DmsfFileRevisions ID #{dmsf_file_revision.id}: Origin '#{origin}' doesn't exist" say msg Rails.logger.error msg end else msg = "DmsfFileRevisions ID #{dmsf_file_revision.id}: disk_file = nil" say msg Rails.logger.error msg end else msg = "DmsfFile ID #{dmsf_file_revision.dmsf_file.id}: project = nil" say msg Rails.logger.error msg end else msg = "DmsfFileRevisions ID #{dmsf_file_revision.id}: dmsf_file = nil" say msg Rails.logger.error msg end end end def storage_base_path(dmsf_file_revision) if dmsf_file_revision.dmsf_file if dmsf_file_revision.dmsf_file.project project_base = dmsf_file_revision.dmsf_file.project.identifier.gsub(/[^\w\.\-]/,'_') return "#{DmsfFile.storage_path}/p_#{project_base}" end end nil end def disk_file(dmsf_file_revision) path = storage_base_path(dmsf_file_revision) if path FileUtils.mkdir_p(path) unless File.exist?(path) return "#{path}/#{dmsf_file_revision.disk_filename}" end nil end end