设计 - 自动删除在定义的时间段后尚未确认的帐户

时间:2011-06-09 09:40:45

标签: ruby-on-rails ruby-on-rails-3 devise

所有内容都在标题中,我希望能够删除在一段时间后尚未确认的帐户

我正在使用:

  • Rails 3.0.5
  • 设计1.3.4

我的设计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

有关详细信息,请参阅他的回答。 非常感谢@很多。

1 个答案:

答案 0 :(得分:10)

您可以使用守护进程(例如cron)运行rake任务。

在此rake中,您可以获取所有未确认的用户(:confirmed_atnil),并在发送确认电子邮件时获取: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