Skip to content

Commit

Permalink
feat: add logs on recent data when error occur (Interlincx#1)
Browse files Browse the repository at this point in the history
  • Loading branch information
josebmendozam committed Jul 7, 2023
1 parent 190502c commit a9e8dd6
Showing 1 changed file with 18 additions and 2 deletions.
20 changes: 18 additions & 2 deletions index.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,18 +8,34 @@ var multileveldown = require('multileveldown')

var DB_CLOSED = process.env.DB_CLOSED === 'true'
var DB = process.env.DB || path.join(__dirname, 'db')

var EXTENDED_LOGS = ['arborist', 'blackbird', 'strategis'].some(p => (process.env.HOSTNAME || '').includes(p))
var db = DB_CLOSED ? {} : level(DB)

var server = net.createServer(function (sock) {
var dataBuffer = []
var mldbServer = multileveldown.server(db)

sock.on('data', function (data) {
dataBuffer.push({ data: data.toString(), ts: new Date().toISOString() })
if (dataBuffer.length > 200) dataBuffer.shift()
})

mldbServer.on('error', function (err) {
if(EXTENDED_LOGS) console.log({ dataBuffer, mldbError: err })
sock.destroy()
if (err) return console.error(err)
process.exit(1)
})

sock.on('error', function (err) {
if(EXTENDED_LOGS) console.log({ dataBuffer, socketError: err })
sock.destroy()
if (err) return console.error(err)
process.exit(1)
})

if (!DB_CLOSED) {
sock.pipe(multileveldown.server(db)).pipe(sock)
sock.pipe(mldbServer).pipe(sock)
}
})

Expand Down

0 comments on commit a9e8dd6

Please sign in to comment.