Files

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

202 lines
5.5 KiB
Ruby
Raw Permalink Normal View History

2025-07-18 17:36:37 +01:00
# frozen_string_literal: true
#-- copyright
2020-01-15 11:31:26 +01:00
# OpenProject is an open source project management software.
# Copyright (C) the OpenProject GmbH
2011-05-30 20:52:25 +02:00
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License version 3.
2011-05-30 20:52:25 +02:00
#
2013-09-16 17:59:31 +02:00
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
2021-01-13 17:47:45 +01:00
# Copyright (C) 2006-2013 Jean-Philippe Lang
2013-09-16 17:59:31 +02:00
# Copyright (C) 2010-2013 the ChiliProject Team
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#
# See COPYRIGHT and LICENSE files for more details.
#++
2009-09-12 08:36:46 +00:00
class GroupsController < ApplicationController
include GroupsHelper
layout "admin"
2011-05-30 20:52:25 +02:00
before_action :require_admin, except: %i[show]
no_authorization_required! :show
2021-04-20 13:45:42 +02:00
before_action :find_group, only: %i[destroy update show create_memberships destroy_membership
edit_membership add_users]
2011-05-30 20:52:25 +02:00
2009-09-12 08:36:46 +00:00
def index
2026-03-25 14:49:50 +01:00
@groups = Group.with_detail.not_organizational_units.in_tree_order
2009-09-12 08:36:46 +00:00
end
def show
2023-05-11 10:13:30 +02:00
@group_users = group_members
render layout: "no_menu"
2009-09-12 08:36:46 +00:00
end
def new
@group = Group.new
end
def edit
@group = Group.includes(:members, :users).find(params[:id])
2009-09-12 08:36:46 +00:00
end
def create
2021-04-20 13:45:42 +02:00
service_call = Groups::CreateService
.new(user: current_user)
.call(permitted_params.group)
@group = service_call.result
2009-09-12 08:36:46 +00:00
2023-05-11 10:13:30 +02:00
if service_call.success?
flash[:notice] = I18n.t(:notice_successful_create)
redirect_to(groups_path)
else
2024-08-28 12:43:09 +02:00
render action: :new, status: :unprocessable_entity
2009-09-12 08:36:46 +00:00
end
end
def update
2021-04-20 13:45:42 +02:00
service_call = Groups::UpdateService
.new(user: current_user, model: @group)
.call(permitted_params.group)
2009-09-12 08:36:46 +00:00
2023-05-11 10:13:30 +02:00
if service_call.success?
flash[:notice] = I18n.t(:notice_successful_update)
redirect_to(groups_path, status: :see_other)
2023-05-11 10:13:30 +02:00
else
2024-08-28 12:43:09 +02:00
render action: :edit, status: :unprocessable_entity
2009-09-12 08:36:46 +00:00
end
end
def destroy
2021-04-20 13:45:42 +02:00
Groups::DeleteService
.new(user: current_user, model: @group)
.call
2009-09-12 08:36:46 +00:00
2023-05-11 10:13:30 +02:00
flash[:info] = I18n.t(:notice_deletion_scheduled)
redirect_to(action: :index, status: :see_other)
2009-09-12 08:36:46 +00:00
end
2011-05-30 20:52:25 +02:00
2009-09-12 08:36:46 +00:00
def add_users
2021-04-20 13:45:42 +02:00
service_call = Groups::UpdateService
.new(user: current_user, model: @group)
.call(add_user_ids: Array(params[:user_ids]))
2021-04-20 13:45:42 +02:00
respond_users_altered(service_call)
2009-09-12 08:36:46 +00:00
end
2011-05-30 20:52:25 +02:00
2009-09-12 08:36:46 +00:00
def remove_user
2021-02-23 09:59:49 +01:00
@group = Group.includes(:group_users).find(params[:id])
2021-04-20 13:45:42 +02:00
service_call = Groups::UpdateService
.new(user: current_user, model: @group)
.call(remove_user_ids: Array(params[:user_id]))
2021-04-20 13:45:42 +02:00
respond_users_altered(service_call)
2009-09-12 08:36:46 +00:00
end
2011-05-30 20:52:25 +02:00
def create_memberships
membership_params = permitted_params.group_membership[:membership]
2021-04-20 13:45:42 +02:00
service_call = Members::CreateService
.new(user: current_user)
.call(membership_params.merge(principal: @group))
respond_membership_altered(service_call)
end
def edit_membership
2013-12-09 11:07:13 +01:00
membership_params = permitted_params.group_membership
2021-04-20 13:45:42 +02:00
@membership = Member.find(membership_params[:membership_id])
2021-04-20 13:45:42 +02:00
service_call = Members::UpdateService
.new(model: @membership, user: current_user)
.call(membership_params[:membership])
2021-04-20 13:45:42 +02:00
respond_membership_altered(service_call)
2009-09-12 08:36:46 +00:00
end
2011-05-30 20:52:25 +02:00
2009-09-12 08:36:46 +00:00
def destroy_membership
2022-01-20 11:23:47 +01:00
member = Member.find(params[:membership_id])
2021-04-20 13:45:42 +02:00
Members::DeleteService
2022-01-20 11:23:47 +01:00
.new(model: member, user: current_user)
2021-04-20 13:45:42 +02:00
.call
2018-03-05 07:40:01 +01:00
flash[:notice] = I18n.t :notice_successful_delete
redirect_to controller: "/groups",
action: "edit",
id: @group,
tab: redirected_to_tab(member),
status: :see_other
2009-09-12 08:36:46 +00:00
end
protected
def find_group
2026-02-02 13:03:58 +01:00
@group = Group.visible.find(params[:id])
end
2017-02-24 13:16:54 +01:00
def group_members
if visible_group_members?
@group.users
else
User.none
end
end
def visible_group_members?
2024-06-20 18:04:41 +02:00
current_user.admin? ||
current_user.allowed_in_any_project?(:manage_members) ||
@group.projects.exists?(id: Project.allowed_to(current_user, :view_members))
end
2021-04-20 13:45:42 +02:00
def respond_membership_altered(service_call)
if service_call.success?
flash[:notice] = I18n.t :notice_successful_update
else
flash[:error] = service_call.errors.full_messages.join("\n")
end
2022-01-20 11:23:47 +01:00
redirect_to controller: "/groups", action: "edit", id: @group, tab: redirected_to_tab(service_call.result)
end
def redirected_to_tab(membership)
if membership.project
"memberships"
else
"global_roles"
end
2021-04-20 13:45:42 +02:00
end
def respond_users_altered(service_call)
if service_call.success?
flash[:notice] = I18n.t(:notice_successful_update)
else
service_call.apply_flash_message!(flash)
end
redirect_to controller: "/groups",
action: "edit",
id: @group,
tab: "users",
status: :see_other
2021-04-20 13:45:42 +02:00
end
2009-09-12 08:36:46 +00:00
end