parent
c8b06d2b08
commit
0b15db3c9a
@ -0,0 +1,37 @@ |
||||
class RenameFixedVersion < ActiveRecord::Migration[6.0] |
||||
def up |
||||
rename_column :work_packages, :fixed_version_id, :version_id |
||||
rename_column :work_package_journals, :fixed_version_id, :version_id |
||||
|
||||
rename_query_attributes('fixed_version', 'version') |
||||
end |
||||
|
||||
def down |
||||
rename_column :work_packages, :version_id, :fixed_version_id |
||||
rename_column :work_package_journals, :version_id, :fixed_version_id |
||||
|
||||
rename_query_attributes('version', 'fixed_version') |
||||
end |
||||
|
||||
def rename_query_attributes(from, to) |
||||
ActiveRecord::Base.connection.exec_query( |
||||
<<-SQL |
||||
UPDATE |
||||
queries q_sink |
||||
SET |
||||
filters = regexp_replace(q_source.filters, '(\n)#{from}_id:(\n)', '\1#{to}_id:\2'), |
||||
column_names = regexp_replace(q_source.column_names, ':#{from}', ':#{to}'), |
||||
sort_criteria = regexp_replace(q_source.sort_criteria, '#{from}', '#{to}'), |
||||
group_by = regexp_replace(q_source.group_by, '#{from}', '#{to}') |
||||
FROM |
||||
queries q_source |
||||
WHERE |
||||
(q_source.filters LIKE '%#{from}_id:%' |
||||
OR q_source.column_names LIKE '%#{from}%' |
||||
OR q_source.sort_criteria LIKE '%#{from}%' |
||||
OR q_source.group_by = '#{from}') |
||||
AND q_sink.id = q_source.id |
||||
SQL |
||||
) |
||||
end |
||||
end |
@ -1,88 +0,0 @@ |
||||
#-- 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. |
||||
#++ |
||||
|
||||
#-- encoding: UTF-8 |
||||
|
||||
# This file included as part of the acts_as_journalized plugin for |
||||
# the redMine project management 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. |
||||
# |
||||
# The original copyright and license conditions are: |
||||
# Copyright (c) 2009 Steve Richert |
||||
# |
||||
# Permission is hereby granted, free of charge, to any person obtaining |
||||
# a copy of this software and associated documentation files (the |
||||
# "Software"), to deal in the Software without restriction, including |
||||
# without limitation the rights to use, copy, modify, merge, publish, |
||||
# distribute, sublicense, and/or sell copies of the Software, and to |
||||
# permit persons to whom the Software is furnished to do so, subject to |
||||
# the following conditions: |
||||
# |
||||
# The above copyright notice and this permission notice shall be |
||||
# included in all copies or substantial portions of the Software. |
||||
# |
||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
||||
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
||||
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
||||
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE |
||||
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION |
||||
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
||||
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
||||
|
||||
module Redmine::Acts::Journalized |
||||
# Ties into the existing ActiveRecord::Base#reload method to ensure that journal information |
||||
# is properly reset. |
||||
module Reload |
||||
def self.included(base) # :nodoc: |
||||
base.class_eval do |
||||
prepend InstanceMethods |
||||
end |
||||
end |
||||
|
||||
# Adds instance methods into ActiveRecord::Base to tap into the +reload+ method. |
||||
module InstanceMethods |
||||
# Overrides ActiveRecord::Base#reload, resetting the instance-variable-cached journal number |
||||
# before performing the original +reload+ method. |
||||
def reload(*args) |
||||
reset_journal |
||||
super |
||||
end |
||||
end |
||||
end |
||||
end |
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in new issue