debian-mirror-gitlab/app/controllers/groups_controller.rb

204 lines
5.3 KiB
Ruby
Raw Normal View History

2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2015-04-26 12:48:37 +05:30
class GroupsController < Groups::ApplicationController
2018-11-20 20:47:30 +05:30
include API::Helpers::RelatedResourcesHelpers
2015-12-23 02:04:40 +05:30
include IssuesAction
include MergeRequestsAction
2017-08-17 22:00:37 +05:30
include ParamsBackwardCompatibility
2018-03-17 18:26:18 +05:30
include PreviewMarkdown
2015-12-23 02:04:40 +05:30
2014-09-02 18:07:02 +05:30
respond_to :html
2016-04-02 18:10:28 +05:30
2018-11-29 20:51:05 +05:30
prepend_before_action(only: [:show, :issues]) { authenticate_sessionless_user!(:rss) }
prepend_before_action(only: [:issues_calendar]) { authenticate_sessionless_user!(:ics) }
2016-06-02 11:05:42 +05:30
before_action :authenticate_user!, only: [:new, :create]
2016-04-02 18:10:28 +05:30
before_action :group, except: [:index, :new, :create]
2014-09-02 18:07:02 +05:30
# Authorize
2018-03-17 18:26:18 +05:30
before_action :authorize_admin_group!, only: [:edit, :update, :destroy, :projects, :transfer]
before_action :authorize_create_group!, only: [:new]
2014-09-02 18:07:02 +05:30
2017-08-17 22:00:37 +05:30
before_action :group_projects, only: [:projects, :activity, :issues, :merge_requests]
2016-06-02 11:05:42 +05:30
before_action :event_filter, only: [:activity]
2014-09-02 18:07:02 +05:30
2018-11-20 20:47:30 +05:30
before_action :user_actions, only: [:show]
2017-08-17 22:00:37 +05:30
2018-03-27 19:54:05 +05:30
skip_cross_project_access_check :index, :new, :create, :edit, :update,
:destroy, :projects
# When loading show as an atom feed, we render events that could leak cross
# project information
skip_cross_project_access_check :show, if: -> { request.format.html? }
2014-09-02 18:07:02 +05:30
layout :determine_layout
2015-09-25 12:07:36 +05:30
def index
redirect_to(current_user ? dashboard_groups_path : explore_groups_path)
end
2014-09-02 18:07:02 +05:30
def new
2018-03-17 18:26:18 +05:30
@group = Group.new(params.permit(:parent_id))
2014-09-02 18:07:02 +05:30
end
def create
2016-06-02 11:05:42 +05:30
@group = Groups::CreateService.new(current_user, group_params).execute
2014-09-02 18:07:02 +05:30
2016-06-02 11:05:42 +05:30
if @group.persisted?
2017-08-17 22:00:37 +05:30
notice = if @group.chat_team.present?
"Group '#{@group.name}' and its Mattermost team were successfully created."
else
"Group '#{@group.name}' was successfully created."
end
redirect_to @group, notice: notice
2014-09-02 18:07:02 +05:30
else
render action: "new"
end
end
def show
respond_to do |format|
2018-11-20 20:47:30 +05:30
format.html
2015-04-26 12:48:37 +05:30
format.atom do
load_events
2017-09-10 17:25:29 +05:30
render layout: 'xml.atom'
2015-04-26 12:48:37 +05:30
end
2014-09-02 18:07:02 +05:30
end
end
2016-06-02 11:05:42 +05:30
def activity
2016-04-02 18:10:28 +05:30
respond_to do |format|
2016-06-02 11:05:42 +05:30
format.html
2016-04-02 18:10:28 +05:30
format.json do
load_events
pager_json("events/_events", @events.count)
end
end
end
2014-09-02 18:07:02 +05:30
def edit
2018-11-20 20:47:30 +05:30
@badge_api_endpoint = expose_url(api_v4_groups_badges_path(id: @group.id))
2014-09-02 18:07:02 +05:30
end
def projects
2017-08-17 22:00:37 +05:30
@projects = @group.projects.with_statistics.page(params[:page])
2014-09-02 18:07:02 +05:30
end
def update
2016-06-02 11:05:42 +05:30
if Groups::UpdateService.new(@group, current_user, group_params).execute
2018-11-20 20:47:30 +05:30
redirect_to edit_group_path(@group, anchor: params[:update_section]), notice: "Group '#{@group.name}' was successfully updated."
2014-09-02 18:07:02 +05:30
else
2017-08-17 22:00:37 +05:30
@group.restore_path!
2014-09-02 18:07:02 +05:30
render action: "edit"
end
end
def destroy
2017-08-17 22:00:37 +05:30
Groups::DestroyService.new(@group, current_user).async_execute
2014-09-02 18:07:02 +05:30
2017-09-10 17:25:29 +05:30
redirect_to root_path, status: 302, alert: "Group '#{@group.name}' was scheduled for deletion."
2014-09-02 18:07:02 +05:30
end
2018-12-05 23:21:45 +05:30
# rubocop: disable CodeReuse/ActiveRecord
2018-03-17 18:26:18 +05:30
def transfer
parent_group = Group.find_by(id: params[:new_parent_group_id])
service = ::Groups::TransferService.new(@group, current_user)
2016-08-24 12:49:21 +05:30
2018-03-17 18:26:18 +05:30
if service.execute(parent_group)
flash[:notice] = "Group '#{@group.name}' was successfully transferred."
redirect_to group_path(@group)
else
flash.now[:alert] = service.error
render :edit
end
2016-08-24 12:49:21 +05:30
end
2018-12-05 23:21:45 +05:30
# rubocop: enable CodeReuse/ActiveRecord
2016-08-24 12:49:21 +05:30
2018-03-17 18:26:18 +05:30
protected
2018-12-05 23:21:45 +05:30
# rubocop: disable CodeReuse/ActiveRecord
2014-09-02 18:07:02 +05:30
def authorize_create_group!
2018-03-17 18:26:18 +05:30
allowed = if params[:parent_id].present?
parent = Group.find_by(id: params[:parent_id])
can?(current_user, :create_subgroup, parent)
else
can?(current_user, :create_group)
end
render_404 unless allowed
2014-09-02 18:07:02 +05:30
end
2018-12-05 23:21:45 +05:30
# rubocop: enable CodeReuse/ActiveRecord
2014-09-02 18:07:02 +05:30
def determine_layout
if [:new, :create].include?(action_name.to_sym)
2015-09-11 14:41:01 +05:30
'application'
elsif [:edit, :update, :projects].include?(action_name.to_sym)
'group_settings'
2014-09-02 18:07:02 +05:30
else
2015-09-11 14:41:01 +05:30
'group'
2014-09-02 18:07:02 +05:30
end
end
def group_params
2018-03-17 18:26:18 +05:30
params.require(:group).permit(group_params_attributes)
2017-08-17 22:00:37 +05:30
end
2018-03-17 18:26:18 +05:30
def group_params_attributes
2017-08-17 22:00:37 +05:30
[
2016-09-29 09:46:39 +05:30
:avatar,
:description,
:lfs_enabled,
:name,
:path,
:public,
:request_access_enabled,
:share_with_group_lock,
2017-08-17 22:00:37 +05:30
:visibility_level,
:parent_id,
:create_chat_team,
:chat_team_name,
:require_two_factor_authentication,
:two_factor_grace_period
]
2014-09-02 18:07:02 +05:30
end
2015-04-26 12:48:37 +05:30
2018-12-05 23:21:45 +05:30
# rubocop: disable CodeReuse/ActiveRecord
2015-04-26 12:48:37 +05:30
def load_events
2018-03-17 18:26:18 +05:30
params[:sort] ||= 'latest_activity_desc'
options = {}
options[:only_owned] = true if params[:shared] == '0'
options[:only_shared] = true if params[:shared] == '1'
@projects = GroupProjectsFinder.new(params: params, group: group, options: options, current_user: current_user)
.execute
.includes(:namespace)
2017-09-10 17:25:29 +05:30
@events = EventCollection
.new(@projects, offset: params[:offset].to_i, filter: event_filter)
.to_a
2018-03-17 18:26:18 +05:30
2018-05-09 12:01:36 +05:30
Events::RenderService
.new(current_user)
.execute(@events, atom_request: request.format.atom?)
2015-04-26 12:48:37 +05:30
end
2018-12-05 23:21:45 +05:30
# rubocop: enable CodeReuse/ActiveRecord
2017-08-17 22:00:37 +05:30
def user_actions
if current_user
@notification_setting = current_user.notification_settings_for(group)
end
end
def build_canonical_path(group)
return group_path(group) if action_name == 'show' # root group path
2017-09-10 17:25:29 +05:30
2017-08-17 22:00:37 +05:30
params[:id] = group.to_param
2018-06-27 16:04:02 +05:30
url_for(safe_params)
2017-08-17 22:00:37 +05:30
end
2014-09-02 18:07:02 +05:30
end