FIX: display total number of other accounts with the same IP address in the IP lookup dialog

This commit is contained in:
Régis Hanol 2014-11-24 19:34:04 +01:00
parent 7b1c001932
commit d3d517108d
6 changed files with 112 additions and 83 deletions

View File

@ -9,6 +9,13 @@ export default Ember.Component.extend({
].filter(Boolean).join(", ");
}.property("location.{city,region,country}"),
otherAccountsToDelete: function() {
// can only delete up to 50 accounts at a time
var total = Math.min(50, this.get("totalOthersWithSameIP") || 0);
var visible = Math.min(50, this.get("other_accounts.length") || 0);
return Math.max(visible, total);
}.property("other_accounts", "totalOthersWithSameIP"),
actions: {
lookup: function () {
var self = this;
@ -24,11 +31,18 @@ export default Ember.Component.extend({
if (!this.get("other_accounts")) {
this.set("otherAccountsLoading", true);
Discourse.AdminUser.findAll("active", {
var data = {
"ip": this.get("ip"),
"exclude": this.get("userId"),
"order": "trust_level DESC"
}).then(function (users) {
};
Discourse.ajax("/admin/users/total-others-with-same-ip.json", { data: data }).then(function (result) {
self.set("totalOthersWithSameIP", result.total);
});
Discourse.AdminUser.findAll("active", data).then(function (users) {
self.setProperties({
other_accounts: users,
otherAccountsLoading: false,
@ -45,7 +59,12 @@ export default Ember.Component.extend({
var self = this;
bootbox.confirm(I18n.t("ip_lookup.confirm_delete_other_accounts"), I18n.t("no_value"), I18n.t("yes_value"), function (confirmed) {
if (confirmed) {
self.setProperties({ other_accounts: null, otherAccountsLoading: true });
self.setProperties({
other_accounts: null,
otherAccountsLoading: true,
totalOthersWithSameIP: null
});
Discourse.ajax("/admin/users/delete-others-with-same-ip.json", {
type: "DELETE",
data: {

View File

@ -39,10 +39,10 @@
<dt>
{{i18n ip_lookup.other_accounts}}
<strong>{{other_accounts.length}}</strong>
<strong>{{totalOthersWithSameIP}}</strong>
{{#if other_accounts.length}}
<button class="btn btn-danger pull-right" {{action "deleteOtherAccounts"}}>
{{fa-icon "warning"}}{{i18n ip_lookup.delete_other_accounts}}
{{fa-icon "warning"}}{{i18n ip_lookup.delete_other_accounts count=otherAccountsToDelete}}
</button>
{{/if}}
</dt>

View File

@ -278,18 +278,24 @@ class Admin::UsersController < Admin::AdminController
params.require(:exclude)
params.require(:order)
params[:limit] = 50
user_destroyer = UserDestroyer.new(current_user)
options = { delete_posts: true, block_email: true, block_urls: true, block_ip: true, delete_as_spammer: true }
AdminUserIndexQuery.new(params).find_users.each do |user|
AdminUserIndexQuery.new(params).find_users(50).each do |user|
user_destroyer.destroy(user, options) rescue nil
end
render json: success_json
end
def total_other_accounts_with_same_ip
params.require(:ip)
params.require(:exclude)
params.require(:order)
render json: { total: AdminUserIndexQuery.new(params).count_users }
end
def invite_admin
email = params[:email]

View File

@ -279,7 +279,7 @@ en:
organisation: Organization
phone: Phone
other_accounts: "Other accounts with this IP address:"
delete_other_accounts: "Delete up to 50"
delete_other_accounts: "Delete %{count}"
username: "username"
trust_level: "TL"
read_time: "read time"

View File

@ -53,6 +53,7 @@ Discourse::Application.routes.draw do
get "list/:query" => "users#index"
get "ip-info" => "users#ip_info"
delete "delete-others-with-same-ip" => "users#delete_other_accounts_with_same_ip"
get "total-others-with-same-ip" => "users#total_other_accounts_with_same_ip"
put "approve-bulk" => "users#approve_bulk"
delete "reject-bulk" => "users#reject_bulk"
end

View File

@ -1,6 +1,7 @@
require_dependency 'trust_level'
class AdminUserIndexQuery
def initialize(params = {}, klass = User, trust_levels = TrustLevel.levels)
@params = params
@query = initialize_query_with_order(klass)
@ -9,6 +10,24 @@ class AdminUserIndexQuery
attr_reader :params, :trust_levels
def find_users(limit=100)
find_users_query.includes(:user_stat)
.includes(:single_sign_on_record)
.includes(:facebook_user_info)
.includes(:twitter_user_info)
.includes(:github_user_info)
.includes(:google_user_info)
.includes(:oauth2_user_info)
.includes(:user_open_ids)
.limit(limit)
end
def count_users
find_users_query.count
end
private
def initialize_query_with_order(klass)
order = [params[:order]]
@ -62,11 +81,6 @@ class AdminUserIndexQuery
end
end
def limit
limit = params[:limit].to_i
@query.limit(limit > 0 ? limit : 100)
end
# this might not be needed in rails 4 ?
def append(active_relation)
@query = active_relation if active_relation
@ -78,18 +92,7 @@ class AdminUserIndexQuery
append filter_by_ip
append filter_exclude
append filter_by_search
append limit
@query
end
def find_users
find_users_query.includes(:user_stat)
.includes(:single_sign_on_record)
.includes(:facebook_user_info)
.includes(:twitter_user_info)
.includes(:github_user_info)
.includes(:google_user_info)
.includes(:oauth2_user_info)
.includes(:user_open_ids)
end
end