mirror of
https://github.com/discourse/discourse.git
synced 2025-01-06 10:43:44 +08:00
55 lines
1.7 KiB
Ruby
55 lines
1.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Jobs
|
|
class EnqueueSuspectUsers < ::Jobs::Scheduled
|
|
every 2.hours
|
|
|
|
def execute(_args)
|
|
return unless SiteSetting.approve_suspect_users
|
|
return if SiteSetting.must_approve_users
|
|
|
|
users = User
|
|
.distinct
|
|
.activated
|
|
.human_users
|
|
.where(approved: false)
|
|
.joins(:user_profile, :user_stat)
|
|
.where("users.created_at <= ? AND users.created_at >= ?", 1.day.ago, 6.months.ago)
|
|
.where("LENGTH(COALESCE(user_profiles.bio_raw, user_profiles.website, '')) > 0")
|
|
.where("user_stats.posts_read_count <= 1 AND user_stats.topics_entered <= 1")
|
|
.joins("LEFT OUTER JOIN reviewables r ON r.target_id = users.id AND r.target_type = 'User'")
|
|
.where('r.id IS NULL')
|
|
.joins('LEFT OUTER JOIN user_custom_fields ucf ON users.id = ucf.user_id')
|
|
.group('users.id, ucf.id')
|
|
.having('ucf.id IS NULL OR NOT bool_or(ucf.name = ?)', 'import_id')
|
|
.limit(10)
|
|
|
|
users.each do |user|
|
|
user_profile = user.user_profile
|
|
|
|
reviewable = ReviewableUser.needs_review!(
|
|
target: user,
|
|
created_by: Discourse.system_user,
|
|
reviewable_by_moderator: true,
|
|
payload: {
|
|
username: user.username,
|
|
name: user.name,
|
|
email: user.email,
|
|
bio: user_profile.bio_raw,
|
|
website: user_profile.website,
|
|
}
|
|
)
|
|
|
|
if reviewable.created_new
|
|
reviewable.add_score(
|
|
Discourse.system_user,
|
|
ReviewableScore.types[:needs_approval],
|
|
reason: :suspect_user,
|
|
force_review: true
|
|
)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|