2021-03-22 23:09:04 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Resolvers
|
|
|
|
class TimelogResolver < BaseResolver
|
|
|
|
include LooksAhead
|
2021-08-10 08:11:00 -04:00
|
|
|
include ResolvesIds
|
2021-03-22 23:09:04 -04:00
|
|
|
|
|
|
|
type ::Types::TimelogType.connection_type, null: false
|
|
|
|
|
|
|
|
argument :start_date, Types::TimeType,
|
2021-06-01 17:10:06 -04:00
|
|
|
required: false,
|
2021-08-10 08:11:00 -04:00
|
|
|
description: 'List timelogs within a date range where the logged date is equal to or after startDate.'
|
2021-03-22 23:09:04 -04:00
|
|
|
|
|
|
|
argument :end_date, Types::TimeType,
|
2021-06-01 17:10:06 -04:00
|
|
|
required: false,
|
2021-08-10 08:11:00 -04:00
|
|
|
description: 'List timelogs within a date range where the logged date is equal to or before endDate.'
|
2021-03-22 23:09:04 -04:00
|
|
|
|
|
|
|
argument :start_time, Types::TimeType,
|
2021-06-01 17:10:06 -04:00
|
|
|
required: false,
|
2021-08-10 08:11:00 -04:00
|
|
|
description: 'List timelogs within a time range where the logged time is equal to or after startTime.'
|
2021-03-22 23:09:04 -04:00
|
|
|
|
|
|
|
argument :end_time, Types::TimeType,
|
2021-06-01 17:10:06 -04:00
|
|
|
required: false,
|
2021-08-10 08:11:00 -04:00
|
|
|
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.'
|
2021-03-22 23:09:04 -04:00
|
|
|
|
|
|
|
def resolve_with_lookahead(**args)
|
2021-08-10 08:11:00 -04:00
|
|
|
validate_args!(object, args)
|
|
|
|
|
|
|
|
timelogs = object&.timelogs || Timelog.limit(GitlabSchema.default_max_page_size)
|
2021-03-22 23:09:04 -04:00
|
|
|
|
2021-06-01 17:10:06 -04:00
|
|
|
if args.any?
|
2021-08-10 08:11:00 -04:00
|
|
|
args = parse_datetime_args(args)
|
|
|
|
|
|
|
|
timelogs = apply_user_filter(timelogs, args)
|
|
|
|
timelogs = apply_project_filter(timelogs, args)
|
|
|
|
timelogs = apply_time_filter(timelogs, args)
|
|
|
|
timelogs = apply_group_filter(timelogs, args)
|
2021-06-01 17:10:06 -04:00
|
|
|
end
|
2021-03-22 23:09:04 -04:00
|
|
|
|
2021-06-01 17:10:06 -04:00
|
|
|
apply_lookahead(timelogs)
|
2021-03-22 23:09:04 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def preloads
|
|
|
|
{
|
|
|
|
note: [:note]
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2021-08-10 08:11:00 -04:00
|
|
|
def validate_args!(object, args)
|
|
|
|
if args.empty? && object.nil?
|
|
|
|
raise_argument_error('Provide at least one argument')
|
|
|
|
elsif args[:start_time] && args[:start_date]
|
2021-06-01 17:10:06 -04:00
|
|
|
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
|
2021-03-22 23:09:04 -04:00
|
|
|
end
|
|
|
|
|
2021-08-10 08:11:00 -04:00
|
|
|
def parse_datetime_args(args)
|
2021-06-01 17:10:06 -04:00
|
|
|
if times_provided?(args)
|
2021-08-10 08:11:00 -04:00
|
|
|
args
|
2021-06-01 17:10:06 -04:00
|
|
|
else
|
2021-08-10 08:11:00 -04:00
|
|
|
parsed_args = args.except(:start_date, :end_date)
|
2021-03-22 23:09:04 -04:00
|
|
|
|
2021-08-10 08:11:00 -04:00
|
|
|
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
|
2021-06-01 17:10:06 -04:00
|
|
|
end
|
2021-03-22 23:09:04 -04:00
|
|
|
end
|
|
|
|
|
2021-06-01 17:10:06 -04:00
|
|
|
def times_provided?(args)
|
|
|
|
args[:start_time] && args[:end_time]
|
2021-03-22 23:09:04 -04:00
|
|
|
end
|
|
|
|
|
2021-08-10 08:11:00 -04:00
|
|
|
def validate_time_difference!(args)
|
|
|
|
return unless end_time_before_start_time?(args)
|
2021-03-22 23:09:04 -04:00
|
|
|
|
2021-06-01 17:10:06 -04:00
|
|
|
raise_argument_error('Start argument must be before End argument')
|
|
|
|
end
|
2021-03-22 23:09:04 -04:00
|
|
|
|
2021-08-10 08:11:00 -04:00
|
|
|
def end_time_before_start_time?(args)
|
|
|
|
times_provided?(args) && args[:end_time] < args[:start_time]
|
2021-03-22 23:09:04 -04:00
|
|
|
end
|
|
|
|
|
2021-08-10 08:11:00 -04:00
|
|
|
def apply_project_filter(timelogs, args)
|
|
|
|
return timelogs unless args[:project_id]
|
|
|
|
|
|
|
|
project = resolve_ids(args[:project_id], ::Types::GlobalIDType[::Project])
|
|
|
|
timelogs.in_project(project)
|
2021-03-22 23:09:04 -04:00
|
|
|
end
|
|
|
|
|
2021-08-10 08:11:00 -04:00
|
|
|
def apply_group_filter(timelogs, args)
|
|
|
|
return timelogs unless args[:group_id]
|
|
|
|
|
|
|
|
group = Group.find_by_id(resolve_ids(args[:group_id], ::Types::GlobalIDType[::Group]))
|
|
|
|
timelogs.in_group(group)
|
|
|
|
end
|
|
|
|
|
|
|
|
def apply_user_filter(timelogs, args)
|
|
|
|
return timelogs unless args[:username]
|
|
|
|
|
|
|
|
user = UserFinder.new(args[:username]).find_by_username!
|
|
|
|
timelogs.for_user(user)
|
|
|
|
end
|
|
|
|
|
|
|
|
def apply_time_filter(timelogs, args)
|
|
|
|
return timelogs unless args[:start_time] || args[:end_time]
|
|
|
|
|
|
|
|
validate_time_difference!(args)
|
|
|
|
|
|
|
|
if args[:start_time]
|
|
|
|
timelogs = timelogs.at_or_after(args[:start_time])
|
|
|
|
end
|
|
|
|
|
|
|
|
if args[:end_time]
|
|
|
|
timelogs = timelogs.at_or_before(args[:end_time])
|
|
|
|
end
|
|
|
|
|
|
|
|
timelogs
|
2021-03-22 23:09:04 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def raise_argument_error(message)
|
|
|
|
raise Gitlab::Graphql::Errors::ArgumentError, message
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|