From 395f7e74c09bf9ec06f5d82ab7a1ad06005d1497 Mon Sep 17 00:00:00 2001 From: Jing T Date: Thu, 19 Jan 2023 18:41:22 +0000 Subject: [PATCH] handle exception for httpGetInitialState() gracefully. (#900) --- src-electron/rest/user-data.js | 30 +++++++++++++++++------------- 1 file changed, 17 insertions(+), 13 deletions(-) diff --git a/src-electron/rest/user-data.js b/src-electron/rest/user-data.js index dbc72eea2d..ca91759806 100644 --- a/src-electron/rest/user-data.js +++ b/src-electron/rest/user-data.js @@ -330,20 +330,24 @@ function httpPostEventUpdate(db) { function httpGetInitialState(db) { return async (request, response) => { let sessionId = request.zapSessionId - let state = {} + let state = { endpointTypes: [], endpoints: [], sessionKeyValues: [] } - let session = await querySession.getSessionFromSessionId(db, sessionId) - asyncValidation.initAsyncValidation(db, session) - - let results = await Promise.all([ - queryEndpointType.selectAllEndpointTypes(db, sessionId), - queryEndpoint.selectAllEndpoints(db, sessionId), - querySession.getAllSessionKeyValues(db, sessionId), - ]) - - state.endpointTypes = results[0] - state.endpoints = results[1] - state.sessionKeyValues = results[2] + try { + let session = await querySession.getSessionFromSessionId(db, sessionId) + await asyncValidation.initAsyncValidation(db, session) + + let results = await Promise.all([ + queryEndpointType.selectAllEndpointTypes(db, sessionId), + queryEndpoint.selectAllEndpoints(db, sessionId), + querySession.getAllSessionKeyValues(db, sessionId), + ]) + + state.endpointTypes = results[0] + state.endpoints = results[1] + state.sessionKeyValues = results[2] + } catch (error) { + console.error(error) + } response.status(StatusCodes.OK).json(state) }