Increase update interval after errors

This commit is contained in:
Samuel Elliott 2025-08-17 20:52:04 +01:00
parent 2e26ea2725
commit f59caa3d6f
No known key found for this signature in database
GPG Key ID: 8420C7CDE43DC4D6
6 changed files with 26 additions and 18 deletions

View File

@ -586,7 +586,6 @@ export class Store extends EventEmitter {
error: err,
buttons: ['OK', 'Retry'],
defaultId: 1,
app: this.app,
});
if (response === 1) {
@ -616,7 +615,6 @@ export class Store extends EventEmitter {
error: err,
buttons: ['OK', 'Retry'],
defaultId: 1,
app: this.app,
});
if (response === 1) {
@ -624,4 +622,4 @@ export class Store extends EventEmitter {
}
}
}
}
}

View File

@ -90,9 +90,8 @@ export function setupIpc(appinstance: App, ipcMain: IpcMain) {
handle('systemPreferences:getloginitem', () => appinstance.store.getLoginItem());
handle('systemPreferences:setloginitem', (e, settings: LoginItemOptions) => appinstance.store.setLoginItem(settings));
handle('preferences:showerroralerts', () => storage.getItem('preferences.showerroralerts'));
handle('preferences:setshowerroralerts', (e, enabled: boolean) =>
storage.setItem('preferences.showerroralerts', enabled));
handle('preferences:getshowerroralerts', () => storage.getItem('ShowErrorAlertsPreference').then(s => s ?? false));
handle('preferences:setshowerroralerts', (e, show: boolean) => storage.setItem('ShowErrorAlertsPreference', show));
handle('update:get', () => appinstance.updater.cache ?? appinstance.updater.check());
handle('update:check', () => appinstance.updater.check());

View File

@ -397,12 +397,14 @@ export class PresenceMonitorManager {
return LoopResult.OK;
}
const show_error_alerts: boolean = await this.app.store.storage.getItem('ShowErrorAlertsPreference') ?? false;
if (!show_error_alerts) return LoopResult.DEFER_NEXT_UPDATE;
const {response} = await showErrorDialog({
message: err.name + ' updating presence monitor',
error: err,
buttons: ['OK', 'Retry'],
defaultId: 0,
app: this.app,
});
if (response === 1) {
@ -432,7 +434,6 @@ export class PresenceMonitorManager {
await showErrorDialog({
message: error.name + ' updating presence monitor',
error,
app: this.app,
});
}
}

View File

@ -77,17 +77,10 @@ interface ErrorBoxOptions extends MessageBoxOptions {
window?: BrowserWindow;
}
export async function showErrorDialog(options: ErrorBoxOptions) {
export function showErrorDialog(options: ErrorBoxOptions) {
const {error, app, window, ...message_box_options} = options;
const detail = ErrorDescription.getErrorDescription(error);
if (app) {
const showErrorAlerts = await app.store.storage.getItem('preferences.showerroralerts') as boolean
if (showErrorAlerts === false) {
return Promise.resolve({ response: 0, checkboxChecked: false });
}
}
message_box_options.detail = message_box_options.detail ?
detail + '\n\n' + message_box_options.detail :
detail;

View File

@ -50,8 +50,8 @@ const ipc = {
getLoginItemSettings: () => inv<LoginItem>('systemPreferences:getloginitem'),
setLoginItemSettings: (settings: LoginItemOptions) => inv('systemPreferences:setloginitem', settings),
getShowErrorAlerts: () => inv<boolean>('preferences:showerroralerts'),
setShowErrorAlerts: (enabled: boolean) => inv('preferences:setshowerroralerts', enabled),
getShowErrorAlerts: () => inv<boolean>('preferences:getshowerroralerts'),
setShowErrorAlerts: (show: boolean) => inv('preferences:setshowerroralerts', show),
getUpdateData: () => inv<UpdateCacheData | null>('update:get'),
checkUpdates: () => inv<UpdateCacheData | null>('update:check'),

View File

@ -4,6 +4,7 @@ const debug = createDebug('nxapi:util:loop');
export default abstract class Loop {
update_interval = 60;
errors = 0;
init(): void | Promise<LoopResult | void> {}
@ -13,8 +14,11 @@ export default abstract class Loop {
try {
const result = init ? await this.init() : await this.update();
this.errors = 0;
return result ?? (init ? LoopResult.OK_SKIP_INTERVAL : LoopResult.OK);
} catch (err) {
this.errors++;
return this.handleError(err as any);
}
}
@ -23,6 +27,10 @@ export default abstract class Loop {
throw err;
}
get next_update_interval() {
return this.update_interval * Math.min(this.errors / 2, 20);
}
private is_loop_active = 0;
async loop(init = false) {
@ -38,6 +46,13 @@ export default abstract class Loop {
await new Promise(rs => setTimeout(this.timeout_resolve = rs, this.update_interval * 1000));
}
}
if (result === LoopResult.DEFER_NEXT_UPDATE) {
if (this.skip_interval_once) {
this.skip_interval_once = false;
} else {
await new Promise(rs => setTimeout(this.timeout_resolve = rs, this.next_update_interval * 1000));
}
}
if (result === LoopResult.STOP) {
return LoopResult.STOP;
}
@ -62,11 +77,13 @@ export default abstract class Loop {
const LoopRunOk = Symbol('LoopRunOk');
const LoopRunOkSkipInterval = Symbol('LoopRunOkSkipInterval');
const LoopRunIncrementInterval = Symbol('LoopRunIncrementInterval');
const LoopRunStop = Symbol('LoopRunStopNow');
export enum LoopResult {
OK = LoopRunOk as any,
OK_SKIP_INTERVAL = LoopRunOkSkipInterval as any,
DEFER_NEXT_UPDATE = LoopRunIncrementInterval as any,
STOP = LoopRunStop as any,
}