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
|
# frozen_string_literal: true
module Resolvers
module Ci
class RunnerJobsResolver < BaseResolver
include Gitlab::Graphql::Authorize::AuthorizeResource
include LooksAhead
type ::Types::Ci::JobType.connection_type, null: true
authorize :read_builds
authorizes_object!
extension ::Gitlab::Graphql::Limit::FieldCallCount, limit: 1
argument :statuses, [::Types::Ci::JobStatusEnum],
required: false,
description: 'Filter jobs by status.'
alias_method :runner, :object
def resolve_with_lookahead(statuses: nil)
context[:job_field_authorization] = :read_build # Instruct JobType to perform field-level authorization
jobs = ::Ci::JobsFinder.new(current_user: current_user, runner: runner, params: { scope: statuses }).execute
apply_lookahead(jobs)
end
private
def preloads
{
previous_stage_jobs_or_needs: [:needs, :pipeline],
artifacts: [:job_artifacts],
pipeline: [:user],
project: [{ project: [:route, { namespace: [:route] }, :project_feature] }],
detailed_status: [
:metadata,
{ pipeline: [:merge_request] },
{ project: [:route, { namespace: :route }] }
],
commit_path: [:pipeline, { project: { namespace: [:route] } }],
ref_path: [{ project: [:route, { namespace: [:route] }] }],
browse_artifacts_path: [{ project: { namespace: [:route] } }],
play_path: [{ project: { namespace: [:route] } }],
web_path: [{ project: { namespace: [:route] } }],
short_sha: [:pipeline],
tags: [:tags],
ai_failure_analysis: [{ project: [:project_feature, :namespace] }],
trace: [{ project: [:namespace] }, :job_artifacts_trace]
}
end
def nested_preloads
super.merge({
trace: {
html_summary: [:trace_chunks]
}
})
end
end
end
end
|