@nxtedition/lib 23.6.12 → 23.6.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/http.js +16 -19
  2. package/package.json +1 -1
package/http.js CHANGED
@@ -169,19 +169,16 @@ export async function requestMiddleware(ctx, next) {
169
169
  req.on('error', noop)
170
170
  res.on('error', noop)
171
171
 
172
+ const isHealthcheck = req.url === '/healthcheck' || req.url === '/_up'
173
+ const reqLogger = isHealthcheck ? null : logger.child({ req })
174
+
172
175
  pendingSet.add(ctx)
173
176
  try {
174
177
  if (req.method === 'GET' || req.method === 'HEAD' || req.method === 'OPTIONS') {
175
178
  req.resume() // Dump the body if there is one.
176
179
  }
177
180
 
178
- const isHealthcheck = req.url === '/healthcheck' || req.url === '/_up'
179
-
180
- if (isHealthcheck) {
181
- // Do nothing...
182
- } else {
183
- logger.debug({ req }, 'request started')
184
- }
181
+ reqLogger?.debug('request started')
185
182
 
186
183
  if (ctx.id) {
187
184
  res.setHeader('request-id', ctx.id)
@@ -200,15 +197,15 @@ export async function requestMiddleware(ctx, next) {
200
197
  if (isHealthcheck) {
201
198
  // Do nothing...
202
199
  } else if (res.errored) {
203
- logger.error({ err: res.errored, res, elapsedTime }, 'request error')
200
+ reqLogger?.error({ err: res.errored, req, res, elapsedTime }, 'request error')
204
201
  } else if (!res.writableEnded) {
205
- logger.debug({ res, elapsedTime }, 'request aborted')
202
+ reqLogger?.debug({ req, res, elapsedTime }, 'request aborted')
206
203
  } else if (res.statusCode >= 500) {
207
- logger.error({ res, elapsedTime }, 'request error')
204
+ reqLogger?.error({ req, res, elapsedTime }, 'request error')
208
205
  } else if (res.statusCode >= 400) {
209
- logger.warn({ res, elapsedTime }, 'request failed')
206
+ reqLogger?.warn({ req, res, elapsedTime }, 'request failed')
210
207
  } else {
211
- logger.debug({ res, elapsedTime }, 'request completed')
208
+ reqLogger?.debug({ req, res, elapsedTime }, 'request completed')
212
209
  }
213
210
  } catch (err) {
214
211
  ctx[kAbortController]?.abort(err)
@@ -248,7 +245,7 @@ export async function requestMiddleware(ctx, next) {
248
245
  }
249
246
  }
250
247
  } else if (err.headers != null) {
251
- logger.warn({ err }, 'invalid headers')
248
+ reqLogger?.warn({ err }, 'invalid headers')
252
249
  }
253
250
 
254
251
  if (fp.isPlainObject(err.body)) {
@@ -263,17 +260,17 @@ export async function requestMiddleware(ctx, next) {
263
260
  }
264
261
 
265
262
  if (statusCode < 500) {
266
- logger.warn({ res, err, elapsedTime }, 'request failed')
263
+ reqLogger?.warn({ res, err, elapsedTime }, 'request failed')
267
264
  } else {
268
- logger.error({ res, err, elapsedTime }, 'request error')
265
+ reqLogger?.error({ res, err, elapsedTime }, 'request error')
269
266
  }
270
267
  } else {
271
268
  if (req.aborted || (!res.errored && res.closed) || err.name === 'AbortError') {
272
- logger.debug({ res, err, elapsedTime }, 'request aborted')
269
+ reqLogger?.debug({ res, err, elapsedTime }, 'request aborted')
273
270
  } else if (statusCode < 500) {
274
- logger.warn({ res, err, elapsedTime }, 'request failed')
271
+ reqLogger?.warn({ res, err, elapsedTime }, 'request failed')
275
272
  } else {
276
- logger.error({ res, err, elapsedTime }, 'request error')
273
+ reqLogger?.error({ res, err, elapsedTime }, 'request error')
277
274
  }
278
275
  res.destroy(err)
279
276
  }
@@ -282,7 +279,7 @@ export async function requestMiddleware(ctx, next) {
282
279
 
283
280
  if (!res.writableEnded && !res.destroyed) {
284
281
  res.destroy()
285
- logger.debug('request destroyed')
282
+ reqLogger?.warn('request destroyed')
286
283
  }
287
284
  }
288
285
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nxtedition/lib",
3
- "version": "23.6.12",
3
+ "version": "23.6.13",
4
4
  "license": "MIT",
5
5
  "author": "Robert Nagy <robert.nagy@boffins.se>",
6
6
  "type": "module",