annotate db/migrate/20100129193402_change_users_mail_notification_to_string.rb @ 929:5f33065ddc4b redmine-1.3

Update to Redmine SVN rev 9414 on 1.3-stable branch
author Chris Cannam
date Wed, 27 Jun 2012 14:54:18 +0100
parents 8661b858af72
children dffacf8a6908
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@119 5 User.update_all("mail_notification = 'all'", "mail_notification_bool = #{connection.quoted_true}")
Chris@119 6 User.update_all("mail_notification = 'selected'", "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@119 7 User.update_all("mail_notification = 'only_my_events'", "mail_notification NOT IN ('all', 'selected')")
Chris@119 8 remove_column :users, :mail_notification_bool
chris@37 9 end
chris@37 10
chris@37 11 def self.down
Chris@119 12 rename_column :users, :mail_notification, :mail_notification_char
Chris@119 13 add_column :users, :mail_notification, :boolean, :default => true, :null => false
Chris@119 14 User.update_all("mail_notification = #{connection.quoted_false}", "mail_notification_char <> 'all'")
Chris@119 15 remove_column :users, :mail_notification_char
chris@37 16 end
chris@37 17 end