summaryrefslogtreecommitdiff
path: root/app/controllers/concerns/cycle_analytics_params.rb
diff options
context:
space:
mode:
Diffstat (limited to 'app/controllers/concerns/cycle_analytics_params.rb')
-rw-r--r--app/controllers/concerns/cycle_analytics_params.rb25
1 files changed, 24 insertions, 1 deletions
diff --git a/app/controllers/concerns/cycle_analytics_params.rb b/app/controllers/concerns/cycle_analytics_params.rb
index b970bdc544e..1645af695be 100644
--- a/app/controllers/concerns/cycle_analytics_params.rb
+++ b/app/controllers/concerns/cycle_analytics_params.rb
@@ -3,8 +3,20 @@
module CycleAnalyticsParams
extend ActiveSupport::Concern
+ def cycle_analytics_project_params
+ return {} unless params[:cycle_analytics].present?
+
+ params[:cycle_analytics].permit(:start_date, :created_after, :created_before, :branch_name)
+ end
+
+ def cycle_analytics_group_params
+ return {} unless params[:cycle_analytics].present?
+
+ params[:cycle_analytics].permit(:start_date, :created_after, :created_before, project_ids: [])
+ end
+
def options(params)
- @options ||= { from: start_date(params), current_user: current_user }
+ @options ||= { from: start_date(params), current_user: current_user }.merge(date_range(params))
end
def start_date(params)
@@ -17,6 +29,17 @@ module CycleAnalyticsParams
90.days.ago
end
end
+
+ def date_range(params)
+ {}.tap do |date_range_params|
+ date_range_params[:from] = to_utc_time(params[:created_after]).beginning_of_day if params[:created_after]
+ date_range_params[:to] = to_utc_time(params[:created_before]).end_of_day if params[:created_before]
+ end.compact
+ end
+
+ def to_utc_time(field)
+ Date.parse(field).to_time.utc
+ end
end
CycleAnalyticsParams.prepend_if_ee('EE::CycleAnalyticsParams')