Bulk remove users

I have imported my old data from phpBB3 which went smooth. But I made a mistake by not first cleaning up the old inactive users and still importing them. I now have around 4000 users with no posts I wish to remove.

What is the best way to bulk remove users?

If you really don’t care about these users, then I would do this

  1. make a backup (better safe than sorry)
  2. ssh into your server and type
cd /var/discourse
./launcher enter app
rails c
User.where(post_count: 0).destroy_all

These instructions produce the following error:
[1] pry(main)> User.where(post_count: 0).destroy_all ActiveRecord::StatementInvalid: PG::UndefinedColumn: ERROR: column users.post_count does not exist LINE 1: SELECT "users".* FROM "users" WHERE "users"."post_count" = 0 ^ : SELECT "users".* FROM "users" WHERE "users"."post_count" = 0 from /var/www/discourse/vendor/bundle/ruby/2.3.0/gems/rack-mini-profiler-0.10.1/lib/patches/db/pg.rb:90:in `exec'

This is not really documented I think but if it is please point me in the right direction?

“post count” != “post_count” ??

My bad, the post_count property was moved to another table for optimization reasons.

Here’s the updated query

User.joins(:user_stat).where("user_stats.post_count = 0").destroy_all

Thank you, the updated query works!

One of my sites uses SSO and we’re looking to remove users that have never posted and haven’t been seen in a year (to avoid killing users who are just quiet). Is this query valid in the rails console?

User.joins(:user_stat).where("user_stats.post_count = 0 AND previous_visit_at <= '2016-05-20'::timestamp").destroy_all

It looks good to me.

Tenho o mesmo problema, mas com usuários que preciso remover antes de fazer a importação final. Tenho trabalhado na criação de uma configuração base com todas as configurações/temas/o que for antes de fazer a importação — agora (depois de muito trabalho) descobri que fiz isso em uma importação parcial que já havia importado 4000 usuários.

Quero excluí-los para que ninguém receba acidentalmente e-mails de resumos ou qualquer coisa do tipo (quando eu esquecer de alterar essas configurações).

Como adapto essa consulta para que apenas o usuário administrador permaneça?
Há cerca de 4000 na lista de usuários ativos
e cerca de 30 na lista de usuários suspensos.

Obrigado desde já :slight_smile:

Nota: atualmente existe uma classe específica para destruir usuários e registros associados de forma limpa: UserDestroyer.

Portanto, em vez disso:

Isso deve ser feito:

destroyer = UserDestroyer.new(Discourse.system_user)
User.joins(:user_stat).where("user_stats.post_count = 0").each { |u| destroyer.destroy(u) }