2018-11-18 11:00:15 +05:30
|
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
2016-06-02 11:05:42 +05:30
|
|
|
|
module Groups
|
|
|
|
|
class CreateService < Groups::BaseService
|
|
|
|
|
def initialize(user, params = {})
|
|
|
|
|
@current_user, @params = user, params.dup
|
2017-08-17 22:00:37 +05:30
|
|
|
|
@chat_team = @params.delete(:create_chat_team)
|
2016-06-02 11:05:42 +05:30
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def execute
|
|
|
|
|
@group = Group.new(params)
|
|
|
|
|
|
2019-03-02 22:35:43 +05:30
|
|
|
|
after_build_hook(@group, params)
|
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
|
unless can_use_visibility_level? && can_create_group?
|
2017-08-17 22:00:37 +05:30
|
|
|
|
return @group
|
|
|
|
|
end
|
|
|
|
|
|
2016-06-02 11:05:42 +05:30
|
|
|
|
@group.name ||= @group.path.dup
|
2017-08-17 22:00:37 +05:30
|
|
|
|
|
|
|
|
|
if create_chat_team?
|
|
|
|
|
response = Mattermost::CreateTeamService.new(@group, current_user).execute
|
|
|
|
|
return @group if @group.errors.any?
|
|
|
|
|
|
|
|
|
|
@group.build_chat_team(name: response['name'], team_id: response['id'])
|
|
|
|
|
end
|
|
|
|
|
|
2016-06-02 11:05:42 +05:30
|
|
|
|
@group.save
|
|
|
|
|
@group.add_owner(current_user)
|
|
|
|
|
@group
|
|
|
|
|
end
|
2017-08-17 22:00:37 +05:30
|
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
2019-03-02 22:35:43 +05:30
|
|
|
|
def after_build_hook(group, params)
|
|
|
|
|
# overriden in EE
|
|
|
|
|
end
|
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
|
def create_chat_team?
|
|
|
|
|
Gitlab.config.mattermost.enabled && @chat_team && group.chat_team.nil?
|
|
|
|
|
end
|
2018-03-17 18:26:18 +05:30
|
|
|
|
|
|
|
|
|
def can_create_group?
|
|
|
|
|
if @group.subgroup?
|
|
|
|
|
unless can?(current_user, :create_subgroup, @group.parent)
|
|
|
|
|
@group.parent = nil
|
|
|
|
|
@group.errors.add(:parent_id, 'You don’t have permission to create a subgroup in this group.')
|
|
|
|
|
|
|
|
|
|
return false
|
|
|
|
|
end
|
|
|
|
|
else
|
|
|
|
|
unless can?(current_user, :create_group)
|
|
|
|
|
@group.errors.add(:base, 'You don’t have permission to create groups.')
|
|
|
|
|
|
|
|
|
|
return false
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
true
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def can_use_visibility_level?
|
|
|
|
|
unless Gitlab::VisibilityLevel.allowed_for?(current_user, params[:visibility_level])
|
|
|
|
|
deny_visibility_level(@group)
|
|
|
|
|
return false
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
true
|
|
|
|
|
end
|
2016-06-02 11:05:42 +05:30
|
|
|
|
end
|
|
|
|
|
end
|