f1d3ea63cf
The status is shown for - The author of a commit when viewing a commit - Notes on a commit (regular/diff) - The user that triggered a pipeline when viewing a pipeline - The author of a merge request when viewing a merge request - The author of notes on a merge request (regular/diff) - The author of an issue when viewing an issue - The author of notes on an issue - The author of a snippet when viewing a snippet - The author of notes on a snippet - A user's profile page - The list of members of a group/user
124 lines
3.3 KiB
Ruby
124 lines
3.3 KiB
Ruby
module MembershipActions
|
|
include MembersPresentation
|
|
extend ActiveSupport::Concern
|
|
|
|
def create
|
|
create_params = params.permit(:user_ids, :access_level, :expires_at)
|
|
result = Members::CreateService.new(current_user, create_params).execute(membershipable)
|
|
|
|
if result[:status] == :success
|
|
redirect_to members_page_url, notice: 'Users were successfully added.'
|
|
else
|
|
redirect_to members_page_url, alert: result[:message]
|
|
end
|
|
end
|
|
|
|
def update
|
|
update_params = params.require(root_params_key).permit(:access_level, :expires_at)
|
|
member = membershipable.members_and_requesters.find(params[:id])
|
|
member = Members::UpdateService
|
|
.new(current_user, update_params)
|
|
.execute(member)
|
|
.present(current_user: current_user)
|
|
|
|
present_members([member])
|
|
respond_to do |format|
|
|
format.js { render 'shared/members/update', locals: { member: member } }
|
|
end
|
|
end
|
|
|
|
def destroy
|
|
member = membershipable.members_and_requesters.find(params[:id])
|
|
Members::DestroyService.new(current_user).execute(member)
|
|
|
|
respond_to do |format|
|
|
format.html do
|
|
message = "User was successfully removed from #{source_type}."
|
|
redirect_to members_page_url, notice: message
|
|
end
|
|
|
|
format.js { head :ok }
|
|
end
|
|
end
|
|
|
|
def request_access
|
|
membershipable.request_access(current_user)
|
|
|
|
redirect_to polymorphic_path(membershipable),
|
|
notice: 'Your request for access has been queued for review.'
|
|
end
|
|
|
|
def approve_access_request
|
|
access_requester = membershipable.requesters.find(params[:id])
|
|
Members::ApproveAccessRequestService
|
|
.new(current_user, params)
|
|
.execute(access_requester)
|
|
|
|
redirect_to members_page_url
|
|
end
|
|
|
|
def leave
|
|
member = membershipable.members_and_requesters.find_by!(user_id: current_user.id)
|
|
Members::DestroyService.new(current_user).execute(member)
|
|
|
|
notice =
|
|
if member.request?
|
|
"Your access request to the #{source_type} has been withdrawn."
|
|
else
|
|
"You left the \"#{membershipable.human_name}\" #{source_type}."
|
|
end
|
|
|
|
respond_to do |format|
|
|
format.html do
|
|
redirect_path = member.request? ? member.source : [:dashboard, membershipable.class.to_s.tableize]
|
|
redirect_to redirect_path, notice: notice
|
|
end
|
|
|
|
format.json { render json: { notice: notice } }
|
|
end
|
|
end
|
|
|
|
def resend_invite
|
|
member = membershipable.members.find(params[:id])
|
|
|
|
if member.invite?
|
|
member.resend_invite
|
|
|
|
redirect_to members_page_url, notice: 'The invitation was successfully resent.'
|
|
else
|
|
redirect_to members_page_url, alert: 'The invitation has already been accepted.'
|
|
end
|
|
end
|
|
|
|
protected
|
|
|
|
def membershipable
|
|
raise NotImplementedError
|
|
end
|
|
|
|
def root_params_key
|
|
case membershipable
|
|
when Namespace
|
|
:group_member
|
|
when Project
|
|
:project_member
|
|
else
|
|
raise "Unknown membershipable type: #{membershipable}!"
|
|
end
|
|
end
|
|
|
|
def members_page_url
|
|
case membershipable
|
|
when Namespace
|
|
polymorphic_url([membershipable, :members])
|
|
when Project
|
|
project_project_members_path(membershipable)
|
|
else
|
|
raise "Unknown membershipable type: #{membershipable}!"
|
|
end
|
|
end
|
|
|
|
def source_type
|
|
@source_type ||= membershipable.class.to_s.humanize(capitalize: false)
|
|
end
|
|
end
|