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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
# frozen_string_literal: true
module Resolvers
class TimelogResolver < BaseResolver
include LooksAhead
include Gitlab::Graphql::Authorize::AuthorizeResource
type ::Types::TimelogType.connection_type, null: false
argument :start_date, Types::TimeType,
required: false,
description: 'List timelogs within a date range where the logged date is equal to or after startDate.'
argument :end_date, Types::TimeType,
required: false,
description: 'List timelogs within a date range where the logged date is equal to or before endDate.'
argument :start_time, Types::TimeType,
required: false,
description: 'List timelogs within a time range where the logged time is equal to or after startTime.'
argument :end_time, Types::TimeType,
required: false,
description: 'List timelogs within a time range where the logged time is equal to or before endTime.'
argument :project_id, ::Types::GlobalIDType[::Project],
required: false,
description: 'List timelogs for a project.'
argument :group_id, ::Types::GlobalIDType[::Group],
required: false,
description: 'List timelogs for a group.'
argument :username, GraphQL::Types::String,
required: false,
description: 'List timelogs for a user.'
argument :sort, Types::TimeTracking::TimelogSortEnum,
description: 'List timelogs in a particular order.',
required: false,
default_value: :spent_at_asc
def resolve_with_lookahead(**args)
validate_args!(object, args)
args = parse_datetime_args(args)
timelogs = Timelogs::TimelogsFinder.new(object, finder_params(args)).execute
apply_lookahead(timelogs)
rescue ArgumentError => e
raise_argument_error(e.message)
rescue ActiveRecord::RecordNotFound
raise_resource_not_available_error!
end
private
def finder_params(args)
{
username: args[:username],
start_time: args[:start_time],
end_time: args[:end_time],
group_id: args[:group_id]&.model_id,
project_id: args[:project_id]&.model_id,
sort: args[:sort]
}
end
def preloads
{
note: [:note]
}
end
def validate_args!(object, args)
# sort is always provided because of its default value so we
# should check the remaining args to make sure at least one filter
# argument was provided
cleaned_args = args.except(:sort)
if cleaned_args.empty? && object.nil?
raise_argument_error('Provide at least one argument')
elsif args[:start_time] && args[:start_date]
raise_argument_error('Provide either a start date or time, but not both')
elsif args[:end_time] && args[:end_date]
raise_argument_error('Provide either an end date or time, but not both')
end
end
def parse_datetime_args(args)
if times_provided?(args)
args
else
parsed_args = args.except(:start_date, :end_date)
parsed_args[:start_time] = args[:start_date].beginning_of_day if args[:start_date]
parsed_args[:end_time] = args[:end_date].end_of_day if args[:end_date]
parsed_args
end
end
def times_provided?(args)
args[:start_time] && args[:end_time]
end
def raise_argument_error(message)
raise Gitlab::Graphql::Errors::ArgumentError, message
end
end
end
|