From 117f8d771a637d981e678300b8cb1f1d1ada42a6 Mon Sep 17 00:00:00 2001 From: Ben Gotow Date: Mon, 16 Oct 2017 13:06:51 -0700 Subject: [PATCH] Throttle calls to ensureClients for better handling of repeated exceptions --- app/src/flux/mailsync-bridge.es6 | 34 +++++++++++++++++--------------- 1 file changed, 18 insertions(+), 16 deletions(-) diff --git a/app/src/flux/mailsync-bridge.es6 b/app/src/flux/mailsync-bridge.es6 index aa544235b..ee909eea9 100644 --- a/app/src/flux/mailsync-bridge.es6 +++ b/app/src/flux/mailsync-bridge.es6 @@ -1,6 +1,7 @@ import path from 'path'; import fs from 'fs'; import { ipcRenderer } from 'electron'; +import _ from 'underscore'; import Task from './tasks/task'; import TaskQueue from './stores/task-queue'; @@ -166,7 +167,7 @@ export default class MailsyncBridge { return this._clients; } - ensureClients() { + ensureClients = _.throttle(() => { const clientsWithoutAccounts = Object.assign({}, this._clients); for (const acct of AccountStore.accounts()) { @@ -185,7 +186,7 @@ export default class MailsyncBridge { for (const client of Object.values(clientsWithoutAccounts)) { client.kill(); } - } + }, 100); forceRelaunchClient(account) { this._launchClient(account, { force: true }); @@ -227,22 +228,23 @@ export default class MailsyncBridge { client.on('deltas', this._onIncomingMessages); client.on('close', ({ code, error, signal }) => { delete this._clients[id]; - if (signal !== 'SIGTERM') { - this._crashTracker.recordClientCrash(fullAccountJSON, { code, error, signal }); + if (signal === 'SIGTERM') { + return; + } + this._crashTracker.recordClientCrash(fullAccountJSON, { code, error, signal }); - const isAuthFailure = - `${error}`.includes('Response Code: 401') || // mailspring services - `${error}`.includes('Response Code: 403') || // mailspring services - `${error}`.includes('ErrorAuthentication'); // mailcore + const isAuthFailure = + `${error}`.includes('Response Code: 401') || // mailspring services + `${error}`.includes('Response Code: 403') || // mailspring services + `${error}`.includes('ErrorAuthentication'); // mailcore - if (this._crashTracker.tooManyFailures(fullAccountJSON)) { - Actions.updateAccount(id, { - syncState: isAuthFailure ? Account.SYNC_STATE_AUTH_FAILED : Account.SYNC_STATE_ERROR, - syncError: { code, error, signal }, - }); - } else { - this.ensureClients(); - } + if (this._crashTracker.tooManyFailures(fullAccountJSON)) { + Actions.updateAccount(id, { + syncState: isAuthFailure ? Account.SYNC_STATE_AUTH_FAILED : Account.SYNC_STATE_ERROR, + syncError: { code, error, signal }, + }); + } else { + this.ensureClients(); } }); this._clients[id] = client;