* Need to check for 't' values to support sqlite
* Need to check the membership count for the 'selected' option
Based on patch contributed by Felix Schäfer
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@4246
e93f8b46-1217-0410-a6f0-
8f06a7374b81
# Patch the data from a boolean change.
class UpdateMailNotificationValues < ActiveRecord::Migration
def self.up
- User.update_all("mail_notification = 'all'", "mail_notification = '1'")
- User.update_all("mail_notification = 'only_my_events'", "mail_notification = '0'")
+ User.record_timestamps = false
+ User.all.each do |u|
+ u.mail_notification = if u.mail_notification =~ /\A(1|t)\z/
+ # User set for all email (t is for sqlite)
+ 'all'
+ else
+ # User wants to recieve notifications on specific projects?
+ if u.memberships.count(:conditions => {:mail_notification => true}) > 0
+ 'selected'
+ else
+ 'only_my_events'
+ end
+ end
+ u.save!
+ end
+ User.record_timestamps = true
end
def self.down