From 12598ba1fd5c52fc9a624373b0679975e2f0220e Mon Sep 17 00:00:00 2001
From: Daniel Huth <4455258+Agreon@users.noreply.github.com>
Date: Sat, 16 Sep 2023 06:55:15 +0200
Subject: [PATCH] Fix Notification mail race condition
---
client/components/InfoSource/InfoSourceOptions.tsx | 2 +-
notifier/src/mail-service.ts | 9 ++++-----
notifier/src/notification-service.ts | 4 ++++
resolver/src/resolve-service.ts | 12 ++++++------
4 files changed, 15 insertions(+), 12 deletions(-)
diff --git a/client/components/InfoSource/InfoSourceOptions.tsx b/client/components/InfoSource/InfoSourceOptions.tsx
index a4520329..d01af0f0 100644
--- a/client/components/InfoSource/InfoSourceOptions.tsx
+++ b/client/components/InfoSource/InfoSourceOptions.tsx
@@ -54,7 +54,7 @@ export const InfoSourceOptions: React.FC = () => {
Do you not want to be bothered again or should we keep searching
- for alternatives?
+ for alternatives with search term {"'"}{game.search}{"'"}?
diff --git a/notifier/src/mail-service.ts b/notifier/src/mail-service.ts
index 153cfabe..a7e577a5 100644
--- a/notifier/src/mail-service.ts
+++ b/notifier/src/mail-service.ts
@@ -33,18 +33,17 @@ export class MailService {
const game = notification.game.getEntity();
const infoSource = notification.infoSource.getEntity();
- const gameName = game.name || game.search;
// We rather display the resolved name so a user can see instantly if an unrelated
// game was added.
const infoSourceName = infoSource.data.fullName;
switch (notification.type) {
case NotificationType.GameReleased:
- return `${gameName} will be available today in the ${infoSource.type} store`;
+ return `${infoSourceName} will be available today in the ${infoSource.type} store`;
case NotificationType.GameReduced:
- return `${gameName} was reduced in the ${infoSource.type} store`;
+ return `${infoSourceName} was reduced in the ${infoSource.type} store`;
case NotificationType.ReleaseDateChanged:
- return `The release date of ${gameName} changed`;
+ return `The release date of ${infoSourceName} changed`;
case NotificationType.NewStoreEntry:
return `${infoSourceName} was added to the ${infoSource.type} store`;
case NotificationType.NewMetacriticRating:
@@ -56,7 +55,7 @@ export class MailService {
case NotificationType.LeftEarlyAccess:
return `${infoSourceName} left Early Access`;
case NotificationType.ResolveError:
- return `${gameName} could not be resolved`;
+ return `${game.name || game.search} could not be resolved`;
}
}
diff --git a/notifier/src/notification-service.ts b/notifier/src/notification-service.ts
index 12cc2f13..bb1914fc 100644
--- a/notifier/src/notification-service.ts
+++ b/notifier/src/notification-service.ts
@@ -49,6 +49,10 @@ export class NotificationService {
{ populate: ['game', 'user'] }
);
const game = infoSource.game.getEntity();
+ if (!game.setupCompleted) {
+ return;
+ }
+
const user = infoSource.user.getEntity();
const logger = this.sourceScopedLogger.child({
diff --git a/resolver/src/resolve-service.ts b/resolver/src/resolve-service.ts
index c1dc43e9..bbc788ac 100644
--- a/resolver/src/resolve-service.ts
+++ b/resolver/src/resolve-service.ts
@@ -71,6 +71,12 @@ export class ResolveService {
logger.debug(`Resolved source information in ${source.type}`);
+ await this.em.nativeUpdate(InfoSource, sourceId, {
+ state: InfoSourceState.Resolved,
+ data: resolvedGameData,
+ updatedAt: new Date()
+ });
+
if (!triggeredManually) {
await this.addToNotificationQueue({
sourceId,
@@ -79,12 +85,6 @@ export class ResolveService {
});
}
- await this.em.nativeUpdate(InfoSource, sourceId, {
- state: InfoSourceState.Resolved,
- data: resolvedGameData,
- updatedAt: new Date()
- });
-
// Delete old, unnecessary ResolveError notifications so that on a new error a
// new notification is created.
await this.em.nativeDelete(Notification, {