From 97cc7eb804481dccef2097c7f7fbcb467f0bc46f Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Wed, 20 Oct 2021 16:36:38 -0500 Subject: [PATCH] Streaming: fail gracefully when WebSocket construction fails (mainly for Bromite browser) --- app/soapbox/stream.js | 56 ++++++++++++++++++++++++------------------- 1 file changed, 32 insertions(+), 24 deletions(-) diff --git a/app/soapbox/stream.js b/app/soapbox/stream.js index 15764f4ce..c6d648d7d 100644 --- a/app/soapbox/stream.js +++ b/app/soapbox/stream.js @@ -26,37 +26,45 @@ export function connectStream(path, pollingRefresh = null, callbacks = () => ({ } }; - const subscription = getStream(streamingAPIBaseURL, accessToken, path, { - connected() { - if (pollingRefresh) { - clearPolling(); - } + let subscription; - onConnect(); - }, + // If the WebSocket fails to be created, don't crash the whole page, + // just proceed without a subscription. + try { + subscription = getStream(streamingAPIBaseURL, accessToken, path, { + connected() { + if (pollingRefresh) { + clearPolling(); + } - disconnected() { - if (pollingRefresh) { - polling = setTimeout(() => setupPolling(), randomIntUpTo(40000)); - } + onConnect(); + }, - onDisconnect(); - }, + disconnected() { + if (pollingRefresh) { + polling = setTimeout(() => setupPolling(), randomIntUpTo(40000)); + } - received(data) { - onReceive(data); - }, + onDisconnect(); + }, - reconnected() { - if (pollingRefresh) { - clearPolling(); - pollingRefresh(dispatch); - } + received(data) { + onReceive(data); + }, - onConnect(); - }, + reconnected() { + if (pollingRefresh) { + clearPolling(); + pollingRefresh(dispatch); + } - }); + onConnect(); + }, + + }); + } catch (e) { + console.error(e); + } const disconnect = () => { if (subscription) {