1
0
espelhamento de https://github.com/redmine/redmine.git sincronizado 2024-07-27 20:19:39 +02:00
redmine/db/migrate/20180923082945_change_sqlite_booleans_to_0_and_1.rb
Go MAEDA fdba424d77 Use match? instead of =~ when MatchData is not used (#34150).
Patch by Go MAEDA.


git-svn-id: http://svn.redmine.org/redmine/trunk@20168 e93f8b46-1217-0410-a6f0-8f06a7374b81
2020-10-23 00:13:38 +00:00

47 linhas
1.5 KiB
Ruby

class ChangeSqliteBooleansTo0And1 < ActiveRecord::Migration[5.2]
COLUMNS = {
AuthSource => ['onthefly_register', 'tls'],
CustomFieldEnumeration => ['active'],
CustomField => ['is_required', 'is_for_all', 'is_filter', 'searchable', 'editable', 'visible', 'multiple'],
EmailAddress => ['is_default', 'notify'],
Enumeration => ['is_default', 'active'],
Import => ['finished'],
IssueStatus => ['is_closed'],
Issue => ['is_private'],
Journal => ['private_notes'],
Member => ['mail_notification'],
Message => ['locked'],
Project => ['is_public', 'inherit_members'],
Repository => ['is_default'],
Role => ['assignable', 'all_roles_managed'],
Tracker => ['is_in_chlog', 'is_in_roadmap'],
UserPreference => ['hide_mail'],
User => ['admin', 'must_change_passwd'],
WikiPage => ['protected'],
WorkflowRule => ['assignee', 'author'],
}
def up
if /sqlite/i.match?(ActiveRecord::Base.connection.adapter_name)
COLUMNS.each do |klass, columns|
columns.each do |column|
klass.where("#{column} = 't'").update_all(column => 1)
klass.where("#{column} = 'f'").update_all(column => 0)
end
end
end
end
def down
if /sqlite/i.match?(ActiveRecord::Base.connection.adapter_name)
COLUMNS.each do |klass, columns|
columns.each do |column|
klass.where("#{column} = 1").update_all(column => 't')
klass.where("#{column} = 0").update_all(column => 'f')
end
end
end
end
end