@nxtedition/nxt-undici 6.0.12 → 6.0.15

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.
@@ -1,9 +1,7 @@
1
1
  import net from 'node:net'
2
- import { resolve4 } from 'node:dns/promises'
2
+ import { resolve4 } from 'node:dns'
3
3
  import { DecoratorHandler, getFastNow } from '../utils.js'
4
4
 
5
- function noop() {}
6
-
7
5
  const MAX_TTL = 10e3
8
6
 
9
7
  class Handler extends DecoratorHandler {
@@ -42,22 +40,32 @@ export default () => (dispatch) => {
42
40
  function resolve(hostname) {
43
41
  let promise = promises.get(hostname)
44
42
  if (!promise) {
45
- promise = resolve4(hostname, { ttl: true })
46
- .then((records) => {
47
- const now = getFastNow()
48
- const ret = records.map(({ address, ttl }) => ({
49
- address,
50
- expires: now + Math.min(MAX_TTL, 1e3 * ttl),
51
- pending: 0,
52
- errored: 0,
53
- counter: 0,
54
- }))
43
+ promise = new Promise((resolve) =>
44
+ resolve4(hostname, { ttl: true }, (err, records) => {
45
+ let ret
46
+
47
+ if (err) {
48
+ ret = { error: err }
49
+ } else {
50
+ const now = getFastNow()
51
+ ret = {
52
+ value: records.map(({ address, ttl }) => ({
53
+ address,
54
+ expires: now + Math.min(MAX_TTL, 1e3 * ttl),
55
+ pending: 0,
56
+ errored: 0,
57
+ counter: 0,
58
+ })),
59
+ }
60
+ }
61
+
55
62
  cache.set(hostname, ret)
56
- return ret
57
- })
58
- .finally(() => {
63
+
59
64
  promises.delete(hostname)
60
- })
65
+
66
+ resolve(ret)
67
+ }),
68
+ )
61
69
  promises.set(hostname, promise)
62
70
  }
63
71
  return promise
@@ -74,44 +82,34 @@ export default () => (dispatch) => {
74
82
  return dispatch(opts, handler)
75
83
  }
76
84
 
77
- const { host, hostname } = origin
78
-
79
- const now = getFastNow()
85
+ try {
86
+ const { host, hostname } = origin
80
87
 
81
- let records = cache.get(hostname)
88
+ const now = getFastNow()
82
89
 
83
- if (records == null || records.every((x) => x.expires < now)) {
84
- records = await resolve(hostname)
85
- } else if (records.some((x) => x.expires < now + 1e3)) {
86
- resolve(hostname).catch(noop)
87
- }
90
+ let records = cache.get(hostname)?.value
88
91
 
89
- records.sort((a, b) => {
90
- if (a.errored !== b.errored) {
91
- return a.errored - b.errored
92
+ if (records == null || records.every((x) => x.expires < now)) {
93
+ records = await resolve(hostname)
94
+ } else if (records.some((x) => x.expires < now + 1e3)) {
95
+ resolve(hostname)
92
96
  }
93
97
 
94
- if (a.pending !== b.pending) {
95
- return a.pending - b.pending
96
- }
97
-
98
- return a.counter - b.counter
99
- })
98
+ records.sort(
99
+ (a, b) => a.errored - b.errored || a.pending - b.pending || a.counter - b.counter,
100
+ )
100
101
 
101
- const record = records.find((x) => x.expires >= now)
102
+ const record = records.find((x) => x.expires >= now)
102
103
 
103
- if (!record) {
104
- throw Object.assign(new Error(`No available DNS records found for ${hostname}`), {
105
- code: 'ENOTFOUND',
106
- })
107
- }
104
+ if (!record) {
105
+ throw Object.assign(new Error(`No available DNS records found for ${hostname}`), {
106
+ code: 'ENOTFOUND',
107
+ })
108
+ }
108
109
 
109
- origin.hostname = record.address
110
+ origin.hostname = record.address
110
111
 
111
- record.counter++
112
- record.pending++
113
- try {
114
- return dispatch(
112
+ dispatch(
115
113
  { ...opts, origin, headers: { ...opts.headers, host } },
116
114
  new Handler(handler, (err, statusCode) => {
117
115
  record.pending--
@@ -123,9 +121,11 @@ export default () => (dispatch) => {
123
121
  }
124
122
  }),
125
123
  )
124
+
125
+ record.counter++
126
+ record.pending++
126
127
  } catch (err) {
127
- record.pending--
128
- throw err
128
+ handler.onError(err)
129
129
  }
130
130
  }
131
131
  }
@@ -152,7 +152,7 @@ class Handler extends DecoratorHandler {
152
152
 
153
153
  let retryPromise
154
154
  try {
155
- retryPromise = retryFn(err, this.#retryCount, { ...this.#opts.retry })
155
+ retryPromise = retryFn(err, this.#retryCount, this.#opts)
156
156
  } catch (err) {
157
157
  retryPromise = Promise.reject(err)
158
158
  }
package/lib/utils.js CHANGED
@@ -80,19 +80,21 @@ export function parseContentRange(range) {
80
80
  }
81
81
 
82
82
  export async function retry(err, retryCount, opts) {
83
- if (!opts) {
83
+ let retryOpts = opts?.retry
84
+
85
+ if (retryOpts) {
84
86
  throw err
85
87
  }
86
88
 
87
- if (typeof opts === 'function') {
88
- return opts(err, retryCount, opts, (opts) => retry(err, retryCount, opts))
89
+ if (typeof retryOpts === 'function') {
90
+ return retryOpts(err, retryCount, opts, () => retry(err, retryCount, opts))
89
91
  }
90
92
 
91
- if (typeof opts === 'number') {
92
- opts = { count: opts }
93
+ if (typeof retryOpts === 'number') {
94
+ retryOpts = { count: retryOpts }
93
95
  }
94
96
 
95
- const retryMax = opts?.count ?? 8
97
+ const retryMax = retryOpts?.count ?? 8
96
98
 
97
99
  if (retryCount > retryMax) {
98
100
  throw err
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nxtedition/nxt-undici",
3
- "version": "6.0.12",
3
+ "version": "6.0.15",
4
4
  "license": "MIT",
5
5
  "author": "Robert Nagy <robert.nagy@boffins.se>",
6
6
  "main": "lib/index.js",