OpenProject is the leading open source project management software.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
openproject/db/migrate/migration_utils/module_renamer.rb

91 lines
2.7 KiB

Feature/remove timelog (#8557) * rename costs, introduce budgets * move files from costs to budgets * rename cost_object to budget * remove unused code * move hook - should be turned into standard code in the long run * move type attributes change over to budgets * move patch to work_package proper * move budget menu item up * combine reporting, time and cost module * remove rails based time_entries & reports code * rename cost object filter * adapt menu spec expectations * use cost project module name in administration * include timeline labels in migration * properly place budget linking method * fix permitted params * remove outdated routing spec * adapt budget request specs * ensure order of descendent updates * remove outdated specs * fix checking for reporting to be enabled * fix displaying spent units * fix time entries activity event url * reenable current rate tab * fix path on budget page * allow bulk editing of budgets only in one project scenario * fix sanitizing reference in controller * include module required for format_date * fix reference to correct units from work package spent units * linting * remove outdated spec * remove outdated views and permission references * remove acts_as_event from time_entries There is no atom link for time entries * remove acts_as_event from projects There are no atom links for projects * introduce budget filter for cost reports * remove actions added to removed controller * move time entries to the costs module * factor in view_own permission when calculating time entry visibility * linting * move mounting of time entries * include budgets into api v3 documentation
4 years ago
#-- encoding: UTF-8
#-- copyright
# OpenProject is an open source project management software.
# Copyright (C) 2012-2020 the OpenProject GmbH
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License version 3.
#
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
# Copyright (C) 2006-2017 Jean-Philippe Lang
# Copyright (C) 2010-2013 the ChiliProject Team
#
# 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.
#
# See docs/COPYRIGHT.rdoc for more details.
#++
module Migration
module MigrationUtils
class ModuleRenamer
class << self
def add_to_enabled(new_module, old_modules)
execute <<~SQL
INSERT INTO
enabled_modules (
project_id,
name
)
SELECT
DISTINCT(project_id),
'#{new_module}'
FROM
enabled_modules
WHERE
name IN (#{comma_separated_strings(old_modules)})
SQL
end
def remove_from_enabled(modules)
execute <<~SQL
DELETE FROM
enabled_modules
WHERE
name IN (#{comma_separated_strings(modules)})
SQL
end
def add_to_default(new_modules, old_modules)
# avoid creating the settings implicitly on new installations
setting = Setting.find_by(name: 'default_projects_modules')
return unless setting
cleaned_setting = setting.value - Array(old_modules)
if setting.value != cleaned_setting
Setting.default_projects_modules = cleaned_setting + Array(new_modules)
end
end
def remove_from_default(name)
add_to_default([], name)
end
private
def execute(string)
ActiveRecord::Base.connection.execute string
end
def comma_separated_strings(array)
Array(array).map { |i| "'#{i}'" }.join(', ')
end
end
end
end
end