Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/app
diff options
context:
space:
mode:
Diffstat (limited to 'app')
-rw-r--r--app/controllers/concerns/membership_actions.rb19
-rw-r--r--app/models/user.rb2
2 files changed, 20 insertions, 1 deletions
diff --git a/app/controllers/concerns/membership_actions.rb b/app/controllers/concerns/membership_actions.rb
index b4f5589a059..042adc8479e 100644
--- a/app/controllers/concerns/membership_actions.rb
+++ b/app/controllers/concerns/membership_actions.rb
@@ -4,6 +4,11 @@ module MembershipActions
include MembersPresentation
extend ActiveSupport::Concern
+ included do
+ before_action :authenticate_user!, only: :request_access
+ before_action :already_a_member!, only: :request_access
+ end
+
def update
member = members_and_requesters.find(params[:id])
result = Members::UpdateService
@@ -166,6 +171,20 @@ module MembershipActions
end
end
end
+
+ def authenticate_user!
+ return if current_user
+
+ redirect_to new_user_session_path
+ end
+
+ def already_a_member!
+ member = members_and_requesters.find_by(user_id: current_user.id) # rubocop: disable CodeReuse/ActiveRecord
+ return if member.nil?
+
+ message = member.request? ? _('You have already requested access.') : _('You already have access.')
+ redirect_to polymorphic_path(membershipable), notice: message
+ end
end
MembershipActions.prepend_mod_with('MembershipActions')
diff --git a/app/models/user.rb b/app/models/user.rb
index 87249f7cf1b..3ca48bcb2b7 100644
--- a/app/models/user.rb
+++ b/app/models/user.rb
@@ -1608,7 +1608,7 @@ class User < MainClusterwide::ApplicationRecord
if namespace
namespace.path = username if username_changed?
namespace.name = name if name_changed?
- elsif Feature.disabled?(:create_user_ns_outside_model)
+ elsif Feature.disabled?(:create_personal_ns_outside_model, Feature.current_request)
# TODO: we should no longer need the `type` parameter once we can make the
# the `has_one :namespace` association use the correct class.
# issue https://gitlab.com/gitlab-org/gitlab/-/issues/341070