diff options
author | Mike Greiling <mike@pixelcog.com> | 2017-07-31 17:09:41 -0500 |
---|---|---|
committer | Mike Greiling <mike@pixelcog.com> | 2017-07-31 17:36:47 -0500 |
commit | 1b9b6974fdfb49f10dfdd4bddde05aa8399ff9b1 (patch) | |
tree | cceecd7680db71a601377966ad2584d52384a132 | |
parent | cf2d2cd323ad07783a4953144a7abedf37927633 (diff) | |
download | gitlab-ce-1b9b6974fdfb49f10dfdd4bddde05aa8399ff9b1.tar.gz |
fix mysql syntax for date INTERVAL arithmatic
-rw-r--r-- | lib/gitlab/contributions_calendar.rb | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/lib/gitlab/contributions_calendar.rb b/lib/gitlab/contributions_calendar.rb index c1f84d07477..aa261929fa9 100644 --- a/lib/gitlab/contributions_calendar.rb +++ b/lib/gitlab/contributions_calendar.rb @@ -69,11 +69,15 @@ module Gitlab .and(t[:created_at].lteq(Date.current.end_of_day)) .and(t[:author_id].eq(contributor.id)) - timezone_adjust = "INTERVAL '#{Time.zone.now.utc_offset} SECONDS'" + date_interval = if Gitlab::Database.postgresql? + "INTERVAL '#{Time.zone.now.utc_offset} seconds'" + else + "INTERVAL #{Time.zone.now.utc_offset} SECOND" + end Event.reorder(nil) - .select(t[:project_id], t[:target_type], t[:action], "date(created_at + #{timezone_adjust}) AS date", 'count(id) as total_amount') - .group(t[:project_id], t[:target_type], t[:action], "date(created_at + #{timezone_adjust})") + .select(t[:project_id], t[:target_type], t[:action], "date(created_at + #{date_interval}) AS date", 'count(id) as total_amount') + .group(t[:project_id], t[:target_type], t[:action], "date(created_at + #{date_interval})") .where(conditions) .having(t[:project_id].in(Arel::Nodes::SqlLiteral.new(authed_projects.to_sql))) end |