From e7d80a6c6ae688b8e4bd8e06708fef9decc3b216 Mon Sep 17 00:00:00 2001 From: Gokhan Sari Date: Wed, 24 May 2023 23:49:40 +0300 Subject: [PATCH] Fix time zone for visitor count reports --- backend/pkg/service/sitereport/visitor/main.go | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/backend/pkg/service/sitereport/visitor/main.go b/backend/pkg/service/sitereport/visitor/main.go index fff1fe2f..efcc8a83 100644 --- a/backend/pkg/service/sitereport/visitor/main.go +++ b/backend/pkg/service/sitereport/visitor/main.go @@ -14,7 +14,7 @@ import ( type Datum struct { DateTime time.Time `json:"dateTime"` - VisitorCount *uint64 `json:"visitorCount"` + VisitorCount *uint64 `json:"visitorCount"` } type Report struct { @@ -34,11 +34,12 @@ func Get(dp *depot.Depot, filters *filter.Filters) (*Report, error) { valueSubQuery := q. Select( strings.Join([]string{ - "toStartOfInterval(date_time, @timeWindowInterval) as date_time", + "toStartOfInterval(date_time, @timeWindowInterval, @timeZone) as date_time", "count(distinct visitor_id) as visitor_count", }, ","), map[string]interface{}{ "timeWindowInterval": gorm.Expr(interval2.ToQuery()), + "timeZone": filters.GetTimeZone(), }, ). Group("date_time") @@ -48,7 +49,7 @@ func Get(dp *depot.Depot, filters *filter.Filters) (*Report, error) { strings.Join([]string{ "select", strings.Join([]string{ - "toStartOfInterval(@start, @timeWindowInterval) + interval arrayJoin(range(0, toUInt64(dateDiff('second', @start, @end)), @intervalSeconds)) second as date_time", + "@start + interval arrayJoin(range(0, toUInt64(dateDiff('second', @start, @end)), @intervalSeconds)) second as date_time", "if(date_time > now(), null, 0) as visitor_count", }, ","), }, " "), @@ -56,7 +57,6 @@ func Get(dp *depot.Depot, filters *filter.Filters) (*Report, error) { "end": filters.End, "intervalSeconds": interval2.ToDuration().Seconds(), "start": filters.Start, - "timeWindowInterval": gorm.Expr(interval2.ToQuery()), }, )