mirror of
https://github.com/discourse/discourse.git
synced 2025-05-22 07:53:49 +08:00
FIX: Add unique index on group_requests(group_id, user_id). (#7399)
This commit is contained in:
@ -408,12 +408,13 @@ class GroupsController < ApplicationController
|
||||
def request_membership
|
||||
params.require(:reason)
|
||||
|
||||
unless current_user.staff?
|
||||
RateLimiter.new(current_user, "request_group_membership", 1, 1.day).performed!
|
||||
end
|
||||
|
||||
group = find_group(:id)
|
||||
group_name = group.name
|
||||
|
||||
begin
|
||||
GroupRequest.create!(group: group, user: current_user, reason: params[:reason])
|
||||
rescue ActiveRecord::RecordNotUnique => e
|
||||
return render json: failed_json.merge(error: I18n.t("groups.errors.already_requested_membership")), status: 409
|
||||
end
|
||||
|
||||
usernames = [current_user.username].concat(
|
||||
group.users.where('group_users.owner')
|
||||
@ -432,15 +433,13 @@ class GroupsController < ApplicationController
|
||||
EOF
|
||||
|
||||
post = PostCreator.new(current_user,
|
||||
title: I18n.t('groups.request_membership_pm.title', group_name: group_name),
|
||||
title: I18n.t('groups.request_membership_pm.title', group_name: group.name),
|
||||
raw: raw,
|
||||
archetype: Archetype.private_message,
|
||||
target_usernames: usernames.join(','),
|
||||
skip_validations: true
|
||||
).create!
|
||||
|
||||
GroupRequest.create!(group: group, user: current_user, reason: params[:reason])
|
||||
|
||||
render json: success_json.merge(relative_url: post.topic.relative_url)
|
||||
end
|
||||
|
||||
|
Reference in New Issue
Block a user