From fd7581b036d9e3580e2e0b1e20d7e4c771d8ff83 Mon Sep 17 00:00:00 2001 From: Chocobozzz Date: Wed, 15 Feb 2023 09:02:34 +0100 Subject: Fix "unique viewers" inconsistency with countries --- server/models/view/local-video-viewer.ts | 25 ++++++++++++++++++++----- 1 file changed, 20 insertions(+), 5 deletions(-) (limited to 'server/models') diff --git a/server/models/view/local-video-viewer.ts b/server/models/view/local-video-viewer.ts index 274117e86..c7ac51a03 100644 --- a/server/models/view/local-video-viewer.ts +++ b/server/models/view/local-video-viewer.ts @@ -119,18 +119,32 @@ export class LocalVideoViewerModel extends Model { + let totalViewersDateWhere = '' + + if (startDate) totalViewersDateWhere += ' AND "localVideoViewer"."endDate" >= :startDate' + if (endDate) totalViewersDateWhere += ' AND "localVideoViewer"."startDate" <= :endDate' + + const totalViewersQuery = `SELECT ` + + `COUNT("localVideoViewer"."id") AS "totalViewers" ` + + `FROM "localVideoViewer" ` + + `WHERE "videoId" = :videoId ${totalViewersDateWhere}` + + return LocalVideoViewerModel.sequelize.query(totalViewersQuery, queryOptions) + } + const buildWatchTimePromise = () => { let watchTimeDateWhere = '' + // We know this where is not exact + // But we prefer to take into account only watch section that started and ended **in** the interval if (startDate) watchTimeDateWhere += ' AND "localVideoViewer"."startDate" >= :startDate' if (endDate) watchTimeDateWhere += ' AND "localVideoViewer"."endDate" <= :endDate' const watchTimeQuery = `SELECT ` + - `COUNT("localVideoViewer"."id") AS "totalViewers", ` + `SUM("localVideoViewer"."watchTime") AS "totalWatchTime", ` + `AVG("localVideoViewer"."watchTime") AS "averageWatchTime" ` + `FROM "localVideoViewer" ` + - `INNER JOIN "video" ON "video"."id" = "localVideoViewer"."videoId" ` + `WHERE "videoId" = :videoId ${watchTimeDateWhere}` return LocalVideoViewerModel.sequelize.query(watchTimeQuery, queryOptions) @@ -194,7 +208,8 @@ export class LocalVideoViewerModel extends Model(countriesQuery, queryOptions) } - const [ rowsWatchTime, rowsWatchPeak, rowsCountries ] = await Promise.all([ + const [ rowsTotalViewers, rowsWatchTime, rowsWatchPeak, rowsCountries ] = await Promise.all([ + buildTotalViewersPromise(), buildWatchTimePromise(), buildWatchPeakPromise(), buildCountriesPromise() @@ -212,8 +227,8 @@ export class LocalVideoViewerModel extends Model