From f3e7c519c5e4a784cda06eda13d3088a1aabe799 Mon Sep 17 00:00:00 2001 From: Jeff Ohrstrom Date: Thu, 19 Sep 2024 13:25:28 -0400 Subject: [PATCH] timeout connections after some configurable time (#3805) --- apps/shell/app.js | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/apps/shell/app.js b/apps/shell/app.js index faab93ab7b..a05e06c5fb 100644 --- a/apps/shell/app.js +++ b/apps/shell/app.js @@ -78,6 +78,9 @@ if (process.env.OOD_SSHHOST_ALLOWLIST){ host_allowlist = Array.from(new Set(process.env.OOD_SSHHOST_ALLOWLIST.split(':'))); } +// default is 8 hours. +const wsTimeout = (process.env.OOD_SHELL_WS_TIMEOUT_MS || 28800000) + let hosts = helpers.definedHosts(); let default_sshhost = hosts['default']; hosts['hosts'].forEach((host) => { @@ -146,6 +149,7 @@ wss.on('connection', function connection (ws, req) { cmd = process.env.OOD_SSH_WRAPPER || 'ssh'; ws.isAlive = true; + ws.startedAt = Date.now(); console.log('Connection established'); @@ -200,7 +204,10 @@ wss.on('connection', function connection (ws, req) { const interval = setInterval(function ping() { wss.clients.forEach(function each(ws) { - if (ws.isAlive === false) return ws.terminate(); + const timeUsed = Date.now() - ws.startedAt; + if (ws.isAlive === false || timeUsed > wsTimeout) { + return ws.terminate(); + } ws.isAlive = false; ws.ping();