1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
|
# frozen_string_literal: true
module Projects
module Settings
class DeployKeysPresenter < Gitlab::View::Presenter::Simple
include Gitlab::Utils::StrongMemoize
presents ::Project, as: :project
delegate :size, to: :enabled_keys, prefix: true
delegate :size, to: :available_project_keys, prefix: true
delegate :size, to: :available_public_keys, prefix: true
def new_key
@key ||= DeployKey.new.tap { |dk| dk.deploy_keys_projects.build }
end
# It includes:
# - The deploy keys enabled in the project.
def enabled_keys
strong_memoize(:enabled_keys) do
project.deploy_keys.with_projects
end
end
# NOTE: This method is redundant. Use `available_project_keys` and `available_public_keys` instead.
# It includes:
# - Enabled deploy keys in projects that can be accessed by the user.
# - Instance-level public deploy keys.
# It excludes:
# - The deploy keys enabled in the project.
def available_keys
strong_memoize(:available_keys) do
current_user
.accessible_deploy_keys
.id_not_in(enabled_keys.select(:id))
.with_projects
end
end
# It includes:
# - Enabled deploy keys in projects that can be accessed by the user.
# It excludes:
# - The deploy keys enabled in the project
def available_project_keys
strong_memoize(:available_project_keys) do
current_user.project_deploy_keys.with_projects - enabled_keys
end
end
# It includes:
# - Instance-level public deploy keys.
# It excludes:
# - The deploy keys enabled in the project.
def available_public_keys
strong_memoize(:available_public_keys) do
DeployKey.are_public.with_projects - enabled_keys
end
end
def as_json
serializer = DeployKeys::DeployKeySerializer.new # rubocop: disable CodeReuse/Serializer
opts = { user: current_user, project: project, readable_project_ids: readable_project_ids }
{
enabled_keys: serializer.represent(enabled_keys, opts),
available_project_keys: serializer.represent(available_project_keys, opts),
public_keys: serializer.represent(available_public_keys, opts)
}
end
def form_partial_path
'shared/deploy_keys/project_group_form'
end
private
# Caching all readable project ids for the user that are associated with the queried deploy keys
def readable_project_ids
strong_memoize(:readable_projects_by_id) do
Set.new(user_readable_project_ids)
end
end
# rubocop: disable CodeReuse/ActiveRecord
def user_readable_project_ids
project_ids = (available_project_keys + available_public_keys)
.flat_map { |deploy_key| deploy_key.deploy_keys_projects.map(&:project_id) }
.compact
.uniq
current_user.authorized_projects(Gitlab::Access::GUEST).id_in(project_ids).pluck(:id)
end
# rubocop: enable CodeReuse/ActiveRecord
end
end
end
|