diff options
Diffstat (limited to 'src/lib')
| -rw-r--r-- | src/lib/Database/SB/User/notifications.ts | 41 | ||||
| -rw-r--r-- | src/lib/Utility/fingerprint.ts | 2 |
2 files changed, 39 insertions, 4 deletions
diff --git a/src/lib/Database/SB/User/notifications.ts b/src/lib/Database/SB/User/notifications.ts index 058171a9..21ad827b 100644 --- a/src/lib/Database/SB/User/notifications.ts +++ b/src/lib/Database/SB/User/notifications.ts @@ -8,6 +8,16 @@ export interface UserNotifications { fingerprint: string; } +const subscriptionEndpoint = (subscription: JSON) => { + if (typeof subscription !== "object" || subscription === null) return null; + + return "endpoint" in subscription && + typeof subscription.endpoint === "string" && + subscription.endpoint.length + ? subscription.endpoint + : null; +}; + export const getUserSubscription = async (userId: number) => await sb.from("user_notifications").select("*").eq("user_id", userId); @@ -33,13 +43,38 @@ export const setUserSubscription = async ( userId: number, subscription: JSON, fingerprint: string, -) => - await sb.from("user_notifications").upsert( +) => { + const endpoint = subscriptionEndpoint(subscription); + + if (endpoint) { + const { data } = await sb + .from("user_notifications") + .select("fingerprint, subscription") + .eq("user_id", userId); + + const staleFingerprints = + data + ?.filter( + (existing) => + existing.fingerprint !== fingerprint && + subscriptionEndpoint(existing.subscription as JSON) === endpoint, + ) + .map((existing) => existing.fingerprint) ?? []; + + await Promise.all( + staleFingerprints.map(async (staleFingerprint) => { + await deleteUserSubscription(userId, staleFingerprint); + }), + ); + } + + return await sb.from("user_notifications").upsert( { user_id: userId, updated_at: new Date().toISOString(), subscription: subscription, fingerprint, }, - { onConflict: "user_id" }, + { onConflict: "user_id,fingerprint" }, ); +}; diff --git a/src/lib/Utility/fingerprint.ts b/src/lib/Utility/fingerprint.ts index 73a9a978..5af258d0 100644 --- a/src/lib/Utility/fingerprint.ts +++ b/src/lib/Utility/fingerprint.ts @@ -14,5 +14,5 @@ export const getFingerprint = () => navigator === null || navigator === void 0 ? void 0 : navigator.hardwareConcurrency - }-${new Date().getTimezoneOffset()}`, + }`, ); |