mirror of
https://github.com/discourse/discourse.git
synced 2025-01-09 20:38:36 +08:00
171 lines
5.2 KiB
Ruby
171 lines
5.2 KiB
Ruby
class Admin::GroupsController < Admin::AdminController
|
|
|
|
def index
|
|
groups = Group.order(:name).where("groups.id <> ?", Group::AUTO_GROUPS[:everyone])
|
|
|
|
if search = params[:search].to_s
|
|
groups = groups.where("name ILIKE ?", "%#{search}%")
|
|
end
|
|
|
|
if params[:ignore_automatic].to_s == "true"
|
|
groups = groups.where(automatic: false)
|
|
end
|
|
|
|
render_serialized(groups, BasicGroupSerializer)
|
|
end
|
|
|
|
def show
|
|
render nothing: true
|
|
end
|
|
|
|
def bulk
|
|
render nothing: true
|
|
end
|
|
|
|
def bulk_perform
|
|
group = Group.find(params[:group_id].to_i)
|
|
users_added = 0
|
|
if group.present?
|
|
users = (params[:users] || []).map {|u| u.downcase}
|
|
valid_emails = {}
|
|
valid_usernames = {}
|
|
valid_users = User.where("username_lower IN (:users) OR email IN (:users)", users: users).pluck(:id, :username_lower, :email)
|
|
valid_users.map! do |id, username_lower, email|
|
|
valid_emails[email] = valid_usernames[username_lower] = id
|
|
id
|
|
end
|
|
invalid_users = users.reject! { |u| valid_emails[u] || valid_usernames[u] }
|
|
group.bulk_add(valid_users) if valid_users.present?
|
|
users_added = valid_users.count
|
|
end
|
|
|
|
render json: { success: true, message: I18n.t('groups.success.bulk_add', users_added: users_added), users_not_added: invalid_users }
|
|
end
|
|
|
|
def create
|
|
group = Group.new
|
|
|
|
group.name = (group_params[:name] || '').strip
|
|
save_group(group)
|
|
end
|
|
|
|
def update
|
|
group = Group.find(params[:id])
|
|
|
|
# group rename is ignored for automatic groups
|
|
group.name = group_params[:name] if group_params[:name] && !group.automatic
|
|
save_group(group) { |g| GroupActionLogger.new(current_user, g).log_change_group_settings }
|
|
end
|
|
|
|
def save_group(group)
|
|
group.alias_level = group_params[:alias_level].to_i if group_params[:alias_level].present?
|
|
group.visible = group_params[:visible] == "true"
|
|
grant_trust_level = group_params[:grant_trust_level].to_i
|
|
group.grant_trust_level = (grant_trust_level > 0 && grant_trust_level <= 4) ? grant_trust_level : nil
|
|
|
|
group.automatic_membership_email_domains = group_params[:automatic_membership_email_domains] unless group.automatic
|
|
group.automatic_membership_retroactive = group_params[:automatic_membership_retroactive] == "true" unless group.automatic
|
|
|
|
group.primary_group = group.automatic ? false : group_params["primary_group"] == "true"
|
|
|
|
group.incoming_email = group.automatic ? nil : group_params[:incoming_email]
|
|
|
|
title = group_params[:title] if group_params[:title].present?
|
|
group.title = group.automatic ? nil : title
|
|
|
|
group.flair_url = group_params[:flair_url].presence
|
|
group.flair_bg_color = group_params[:flair_bg_color].presence
|
|
group.flair_color = group_params[:flair_color].presence
|
|
group.public = group_params[:public] if group_params[:public]
|
|
group.bio_raw = group_params[:bio_raw] if group_params[:bio_raw]
|
|
group.full_name = group_params[:full_name] if group_params[:full_name]
|
|
|
|
if group_params.key?(:default_notification_level)
|
|
group.default_notification_level = group_params[:default_notification_level]
|
|
end
|
|
|
|
if group_params[:allow_membership_requests]
|
|
group.allow_membership_requests = group_params[:allow_membership_requests]
|
|
end
|
|
|
|
if group.save
|
|
Group.reset_counters(group.id, :group_users)
|
|
|
|
yield(group) if block_given?
|
|
|
|
render_serialized(group, BasicGroupSerializer)
|
|
else
|
|
render_json_error group
|
|
end
|
|
end
|
|
|
|
def destroy
|
|
group = Group.find(params[:id])
|
|
|
|
if group.automatic
|
|
can_not_modify_automatic
|
|
else
|
|
group.destroy
|
|
render json: success_json
|
|
end
|
|
end
|
|
|
|
def refresh_automatic_groups
|
|
Group.refresh_automatic_groups!
|
|
render json: success_json
|
|
end
|
|
|
|
def add_owners
|
|
group = Group.find(params.require(:id))
|
|
return can_not_modify_automatic if group.automatic
|
|
|
|
users = User.where(username: params[:usernames].split(","))
|
|
|
|
users.each do |user|
|
|
group_action_logger = GroupActionLogger.new(current_user, group)
|
|
|
|
if !group.users.include?(user)
|
|
group.add(user)
|
|
group_action_logger.log_add_user_to_group(user)
|
|
end
|
|
group.group_users.where(user_id: user.id).update_all(owner: true)
|
|
group_action_logger.log_make_user_group_owner(user)
|
|
end
|
|
|
|
Group.reset_counters(group.id, :group_users)
|
|
|
|
render json: success_json
|
|
end
|
|
|
|
def remove_owner
|
|
group = Group.find(params.require(:id))
|
|
return can_not_modify_automatic if group.automatic
|
|
|
|
user = User.find(params[:user_id].to_i)
|
|
group.group_users.where(user_id: user.id).update_all(owner: false)
|
|
GroupActionLogger.new(current_user, group).log_remove_user_as_group_owner(user)
|
|
|
|
Group.reset_counters(group.id, :group_users)
|
|
|
|
render json: success_json
|
|
end
|
|
|
|
protected
|
|
|
|
def can_not_modify_automatic
|
|
render json: {errors: I18n.t('groups.errors.can_not_modify_automatic')}, status: 422
|
|
end
|
|
|
|
private
|
|
|
|
def group_params
|
|
params.require(:group).permit(
|
|
:name, :alias_level, :visible, :automatic_membership_email_domains,
|
|
:automatic_membership_retroactive, :title, :primary_group,
|
|
:grant_trust_level, :incoming_email, :flair_url, :flair_bg_color,
|
|
:flair_color, :bio_raw, :public, :allow_membership_requests, :full_name,
|
|
:default_notification_level
|
|
)
|
|
end
|
|
end
|