所有内容都在标题中,我希望能够删除在一段时间后尚未确认的帐户。
我正在使用:
我的设计User
模型具有以下属性:
devise :database_authenticatable, :confirmable, :registerable, :recoverable, :rememberable, :trackable, :validatable
我的db/schema.rb
create_table "users", :force => true do |t|
t.string "email", :default => "", :null => false
t.string "encrypted_password", :limit => 128, :default => "", :null => false
t.string "reset_password_token"
t.timestamp "reset_password_sent_at"
t.timestamp "remember_created_at"
t.integer "sign_in_count", :default => 0
t.timestamp "current_sign_in_at"
t.timestamp "last_sign_in_at"
t.string "current_sign_in_ip"
t.string "last_sign_in_ip"
t.timestamp "created_at"
t.timestamp "updated_at"
t.string "confirmation_token"
t.timestamp "confirmed_at"
t.timestamp "confirmation_sent_at"
end
小小的奖励 - 在我的User
模型中,我已经指定了我的数据之间的关系,例如:
has_one :user_content, :dependent => :destroy
我想确保其子项也被删除。
非常感谢能帮助的人!
感谢 jrdi ,以下是使用 SQLite 3
的数据库的答案desc "Delete all unconfirmed users after 7 days"
task :delete_unconfirmed_users => :environment do
users = User.all(:conditions => 'confirmed_at is NULL AND confirmation_sent_at <= datetime(\'now\',\'-7 days\')')
users.each do |user|
user.destroy
end
end
PostGRE (Heroku)
desc "Delete all unconfirmed users after 7 days"
task :postgre_delete_unconfirmed_users => :environment do
users = User.all(:conditions => 'confirmed_at is NULL AND confirmation_sent_at <= current_date - integer \'7\' ')
users.each do |user|
user.destroy
end
end
有关详细信息,请参阅他的回答。 非常感谢@很多。
答案 0 :(得分:10)
您可以使用守护进程(例如cron)运行rake任务。
在此rake中,您可以获取所有未确认的用户(:confirmed_at
为nil
),并在发送确认电子邮件时获取:confirmation_sent_at
当您拥有符合规范的用户时,user.destroy
将被正确删除。
如果您需要这个rake任务的示例,请告诉我并进行第一次近似。
---编辑---
在lib / tasks中创建一个delete_unconfirmed_users.rake
desc "Delete all unconfirmed users after 7 days"
task :delete_unconfirmed_users => :environment do
users = User.all(:conditions => 'confirmed_at is NULL AND confirmation_sent_at >= DATE_SUB(NOW(), INTERVAL 7 day)')
users.each do |user|
user.destroy
end
end
运行rake delete_unconfirmed_users