Skip to content
This repository has been archived by the owner on Dec 6, 2023. It is now read-only.

Commit

Permalink
fix(websocket): Implemented a keep alive for the socket connections s…
Browse files Browse the repository at this point in the history
…ince they were dropping after 2 minutes of inactivity.
  • Loading branch information
rmevans9 authored Feb 14, 2019
1 parent 79f62e7 commit a08f1ff
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 36 deletions.
26 changes: 25 additions & 1 deletion src/reactotron-core-server.ts
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,11 @@ export default class Server {
*/
started: boolean = false

/**
* Keep alive interval to be running while the server is up.
*/
keepAlive: NodeJS.Timer

/**
* Set the configuration options.
*/
Expand Down Expand Up @@ -143,6 +148,17 @@ export default class Server {
server.listen(port)
}

if (this.keepAlive) {
clearInterval(this.keepAlive)
}

// In the future we should bake this in more and use it to clean up dropped connections
this.keepAlive = setInterval(() => {
this.wss.clients.forEach((ws) => {
ws.ping(() => {});
});
}, 30000)

// register events
this.wss.on("connection", (socket, request) => {
const thisConnectionId = this.connectionId++
Expand All @@ -160,8 +176,11 @@ export default class Server {
// trigger onConnect
this.emitter.emit("connect", partialConnection)

socket.on("error", error => console.log("ERR", error));

// when this client disconnects
socket.on("close", () => {
console.log('Client disconnected');
// remove them from the list partial list
this.partialConnections = reject(
propEq("id", thisConnectionId),
Expand Down Expand Up @@ -232,7 +251,7 @@ export default class Server {
const currentClientConnections = currentWssConnections.filter(c => (c as any).clientId === connectionClientId)

for (let i = 0; i < currentClientConnections.length; i++) {
setTimeout(currentClientConnections[i].close(), 500) // Defer this for a small amount of time because reasons.
setTimeout(currentClientConnections[i].close, 500) // Defer this for a small amount of time because reasons.

const severingConnection = find(propEq("clientId", connectionClientId), this.connections)
if (severingConnection) {
Expand Down Expand Up @@ -290,6 +309,11 @@ export default class Server {
s => s && (s as any).connected && (s as any).disconnect(),
pluck("socket", this.connections),
)

if (this.keepAlive) {
clearInterval(this.keepAlive)
}

this.wss.close()

// trigger the stop message
Expand Down
38 changes: 3 additions & 35 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -1596,7 +1596,7 @@ debug@^4.0.0:
dependencies:
ms "^2.1.1"

debuglog@*, debuglog@^1.0.1:
debuglog@^1.0.1:
version "1.0.1"
resolved "https://registry.yarnpkg.com/debuglog/-/debuglog-1.0.1.tgz#aa24ffb9ac3df9a2351837cfb2d279360cd78492"
integrity sha1-qiT/uaw9+aI1GDfPstJ5NgzXhJI=
Expand Down Expand Up @@ -2860,7 +2860,7 @@ import-lazy@^2.1.0:
resolved "https://registry.yarnpkg.com/import-lazy/-/import-lazy-2.1.0.tgz#05698e3d45c88e8d7e9d92cb0584e77f096f3e43"
integrity sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=

imurmurhash@*, imurmurhash@^0.1.4:
imurmurhash@^0.1.4:
version "0.1.4"
resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea"

Expand Down Expand Up @@ -3864,11 +3864,6 @@ lockfile@^1.0.4:
dependencies:
signal-exit "^3.0.2"

lodash._baseindexof@*:
version "3.1.0"
resolved "https://registry.yarnpkg.com/lodash._baseindexof/-/lodash._baseindexof-3.1.0.tgz#fe52b53a1c6761e42618d654e4a25789ed61822c"
integrity sha1-/lK1OhxnYeQmGNZU5KJXie1hgiw=

lodash._baseuniq@~4.6.0:
version "4.6.0"
resolved "https://registry.yarnpkg.com/lodash._baseuniq/-/lodash._baseuniq-4.6.0.tgz#0ebb44e456814af7905c6212fa2c9b2d51b841e8"
Expand All @@ -3877,33 +3872,11 @@ lodash._baseuniq@~4.6.0:
lodash._createset "~4.0.0"
lodash._root "~3.0.0"

lodash._bindcallback@*:
version "3.0.1"
resolved "https://registry.yarnpkg.com/lodash._bindcallback/-/lodash._bindcallback-3.0.1.tgz#e531c27644cf8b57a99e17ed95b35c748789392e"
integrity sha1-5THCdkTPi1epnhftlbNcdIeJOS4=

lodash._cacheindexof@*:
version "3.0.2"
resolved "https://registry.yarnpkg.com/lodash._cacheindexof/-/lodash._cacheindexof-3.0.2.tgz#3dc69ac82498d2ee5e3ce56091bafd2adc7bde92"
integrity sha1-PcaayCSY0u5ePOVgkbr9Ktx73pI=

lodash._createcache@*:
version "3.1.2"
resolved "https://registry.yarnpkg.com/lodash._createcache/-/lodash._createcache-3.1.2.tgz#56d6a064017625e79ebca6b8018e17440bdcf093"
integrity sha1-VtagZAF2JeeevKa4AY4XRAvc8JM=
dependencies:
lodash._getnative "^3.0.0"

lodash._createset@~4.0.0:
version "4.0.3"
resolved "https://registry.yarnpkg.com/lodash._createset/-/lodash._createset-4.0.3.tgz#0f4659fbb09d75194fa9e2b88a6644d363c9fe26"
integrity sha1-D0ZZ+7CddRlPqeK4imZE02PJ/iY=

lodash._getnative@*, lodash._getnative@^3.0.0:
version "3.9.1"
resolved "https://registry.yarnpkg.com/lodash._getnative/-/lodash._getnative-3.9.1.tgz#570bc7dede46d61cdcde687d65d3eecbaa3aaff5"
integrity sha1-VwvH3t5G1hzc3mh9ZdPuy6o6r/U=

lodash._root@~3.0.0:
version "3.0.1"
resolved "https://registry.yarnpkg.com/lodash._root/-/lodash._root-3.0.1.tgz#fba1c4524c19ee9a5f8136b4609f017cf4ded692"
Expand Down Expand Up @@ -3949,11 +3922,6 @@ lodash.pick@^4.4.0:
resolved "https://registry.yarnpkg.com/lodash.pick/-/lodash.pick-4.4.0.tgz#52f05610fff9ded422611441ed1fc123a03001b3"
integrity sha1-UvBWEP/53tQiYRRB7R/BI6AwAbM=

lodash.restparam@*:
version "3.6.1"
resolved "https://registry.yarnpkg.com/lodash.restparam/-/lodash.restparam-3.6.1.tgz#936a4e309ef330a7645ed4145986c85ae5b20805"
integrity sha1-k2pOMJ7zMKdkXtQUWYbIWuWyCAU=

lodash.set@^4.3.2:
version "4.3.2"
resolved "https://registry.yarnpkg.com/lodash.set/-/lodash.set-4.3.2.tgz#d8757b1da807dde24816b0d6a84bea1a76230b23"
Expand Down Expand Up @@ -5654,7 +5622,7 @@ readable-stream@~1.1.10:
isarray "0.0.1"
string_decoder "~0.10.x"

readdir-scoped-modules@*, readdir-scoped-modules@^1.0.0:
readdir-scoped-modules@^1.0.0:
version "1.0.2"
resolved "https://registry.yarnpkg.com/readdir-scoped-modules/-/readdir-scoped-modules-1.0.2.tgz#9fafa37d286be5d92cbaebdee030dc9b5f406747"
integrity sha1-n6+jfShr5dksuuve4DDcm19AZ0c=
Expand Down

0 comments on commit a08f1ff

Please sign in to comment.