annotate db/migrate/20100129193402_change_users_mail_notification_to_string.rb @ 1517:dffacf8a6908 redmine-2.5

Update to Redmine SVN revision 13367 on 2.5-stable branch
author Chris Cannam
date Tue, 09 Sep 2014 09:29:00 +0100
parents 8661b858af72
children
rev   line source
chris@37 1 class ChangeUsersMailNotificationToString < ActiveRecord::Migration
chris@37 2 def self.up
Chris@119 3 rename_column :users, :mail_notification, :mail_notification_bool
Chris@119 4 add_column :users, :mail_notification, :string, :default => '', :null => false
Chris@1517 5 User.where("mail_notification_bool = #{connection.quoted_true}").
Chris@1517 6 update_all("mail_notification = 'all'")
Chris@1517 7 User.where("EXISTS (SELECT 1 FROM #{Member.table_name} WHERE #{Member.table_name}.mail_notification = #{connection.quoted_true} AND #{Member.table_name}.user_id = #{User.table_name}.id)").
Chris@1517 8 update_all("mail_notification = 'selected'")
Chris@1517 9 User.where("mail_notification NOT IN ('all', 'selected')").
Chris@1517 10 update_all("mail_notification = 'only_my_events'")
Chris@119 11 remove_column :users, :mail_notification_bool
chris@37 12 end
chris@37 13
chris@37 14 def self.down
Chris@119 15 rename_column :users, :mail_notification, :mail_notification_char
Chris@119 16 add_column :users, :mail_notification, :boolean, :default => true, :null => false
Chris@1517 17 User.where("mail_notification_char <> 'all'").
Chris@1517 18 update_all("mail_notification = #{connection.quoted_false}")
Chris@119 19 remove_column :users, :mail_notification_char
chris@37 20 end
chris@37 21 end