@passcod/faith 0.0.7 → 0.0.9

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.
package/README.md CHANGED
@@ -401,6 +401,15 @@ In HTTP/1, servers can send custom status text. This is returned here. In HTTP/2
401
401
  status text is not supported at all, and the `statusText` property is either empty or simulated
402
402
  from well-known status codes.
403
403
 
404
+ ### `Response.trailers: Promise<Headers | null>`
405
+
406
+ The `trailers()` read-only property of the `Response` interface returns a promise that resolves to
407
+ either `null` or a `Headers` structure that contains the HTTP/2 or /3 trailing headers.
408
+
409
+ Note that this will never resolve if you don't also consume the body in some way.
410
+
411
+ Custom to Fáith. This was once in the spec but was removed as it wasn't implemented by any browser.
412
+
404
413
  ### `Response.type: string`
405
414
 
406
415
  *The `type` read-only property of the `Response` interface contains the type of the response. The
@@ -446,6 +455,20 @@ in every way, but stored in a different variable.*
446
455
 
447
456
  *`clone()` throws an error if the response body has already been used.*
448
457
 
458
+ ### `Response.discard(): Promise<void>`
459
+
460
+ Discard the response body, releasing the connection back to the pool.
461
+
462
+ This is useful when you don't need the body but want to ensure the connection can be reused for
463
+ subsequent requests. If you don't call this and don't consume the body, the connection may be held
464
+ open until the response is garbage collected. When the connection is HTTP/2 or /3, calling this is
465
+ not necessary as the connection can be reused regardless, but it's still good practice to make it
466
+ explicit and won't do unnecessary work in those cases.
467
+
468
+ The returned promise resolves when the body has been fully discarded.
469
+
470
+ This is custom to Fáith.
471
+
449
472
  ### `Response.formData(): !`
450
473
 
451
474
  Fáith deliberately does not implement this. The method exists so the types work out, but it will
@@ -624,6 +647,31 @@ defines bounds for safety: minimum 1 second, maximum 2 minutes (120 seconds).
624
647
 
625
648
  Default: 30.
626
649
 
650
+ #### `AgentOptions.http3.upgradeEnabled: bool`
651
+
652
+ Fáith keeps track of "Alt-Svc" advertisements from the servers, which indicate if and how HTTP/3 is
653
+ available. It then uses those advertisements to attempt connection over HTTP/3, and also keeps
654
+ track of failures, so it doesn't waste time retrying HTTP/3 for hosts that don't actually support
655
+ it even if they did advertise it.
656
+
657
+ Setting this setting to `false` disables this mechanism, which effectively disables HTTP/3 usage.
658
+
659
+ Default: `true`.
660
+
661
+ #### `AgentOptions.http3.hints: Array<{ host: string; port: number }>`
662
+
663
+ If you know upfront that a host has HTTP/3 support, and at what port it's listening, you can skip
664
+ a first HTTP/1 or /2 connection by providing a hint here. If the connection fails, the hint will
665
+ be ignored for the `upgradeFailedTtl` duration, just like for the normal pathway with Alt-Svc
666
+ advertisements (essentially, hints pre-populate the Alt-Svc advertisements cache).
667
+
668
+ #### `AgentOptions.http3.upgradeAdvertisedTtl: number`
669
+ #### `AgentOptions.http3.upgradeConfirmedTtl: number`
670
+ #### `AgentOptions.http3.upgradeFailedTtl: number`
671
+ #### `AgentOptions.http3.upgradeCacheCapacity: number`
672
+
673
+ These four settings allow tweaking the HTTP/3 advertisement/knowledge cache behaviour.
674
+
627
675
  ### `AgentOptions.pool: object`
628
676
 
629
677
  Settings related to the connection pool. This is a nested object.
@@ -750,6 +798,8 @@ Returns statistics gathered by this agent:
750
798
 
751
799
  - `requestsSent`
752
800
  - `responsesReceived`
801
+ - `bodiesStarted`
802
+ - `bodiesFinished`
753
803
 
754
804
  ## Error mapping
755
805
 
@@ -764,6 +814,7 @@ error kind, documented in this comprehensive mapping:
764
814
  - `Network` — network error
765
815
  - `Redirect` — when the agent is configured to error on redirects
766
816
  - JS `SyntaxError`:
817
+ - `AddressParse` — IP parse error for `AgentOptions.dns.overrides`
767
818
  - `JsonParse` — JSON parse error for `response.json()`
768
819
  - `PemParse` — PEM parse error for `AgentOptions.tls.identity`
769
820
  - `Utf8Parse` — UTF8 decoding error for `response.text()`
@@ -786,3 +837,12 @@ constant from `ERROR_CODES`, instead of doing string matching on the error messa
786
837
 
787
838
  Due to technical limitations, when reading a body stream, reads might fail, but that error
788
839
  will not have a `code` property.
840
+
841
+ ## Versions
842
+
843
+ Two version constants are exposed:
844
+
845
+ - `FAITH_VERSION` is the version of the Fáith library itself
846
+ - `REQWEST_VERSION` is the version of the underlying [reqwest](https://github.com/seanmonstar/reqwest) library
847
+
848
+ These can be used to construct your own user agent strings, in logging, or for seeking help.
package/index.d.ts CHANGED
@@ -317,6 +317,44 @@ export interface AgentHttp3Options {
317
317
  * Default: 30.
318
318
  */
319
319
  maxIdleTimeout?: number
320
+ /**
321
+ * Whether HTTP/3 upgrade via Alt-Svc is enabled. When enabled, the agent will track Alt-Svc
322
+ * headers from responses and automatically upgrade subsequent requests to HTTP/3 when available.
323
+ *
324
+ * Default: true.
325
+ */
326
+ upgradeEnabled?: boolean
327
+ /**
328
+ * How long (in seconds) to cache an Alt-Svc advertisement before the first HTTP/3 attempt.
329
+ * This is overridden by the `ma` (max-age) parameter in the Alt-Svc header if present.
330
+ *
331
+ * Default: 86400 (24 hours).
332
+ */
333
+ upgradeAdvertisedTtl?: number
334
+ /**
335
+ * How long (in seconds) to cache a confirmed working HTTP/3 connection.
336
+ *
337
+ * Default: 86400 (24 hours).
338
+ */
339
+ upgradeConfirmedTtl?: number
340
+ /**
341
+ * How long (in seconds) to cache a failed HTTP/3 attempt. During this time, no HTTP/3
342
+ * upgrades will be attempted for the origin, even if the server sends Alt-Svc headers.
343
+ *
344
+ * Default: 300 (5 minutes).
345
+ */
346
+ upgradeFailedTtl?: number
347
+ /**
348
+ * Maximum number of origins to track in the Alt-Svc cache.
349
+ *
350
+ * Default: 10000.
351
+ */
352
+ upgradeCacheCapacity?: number
353
+ /**
354
+ * Hints for hosts that are known to support HTTP/3. These are added to the Alt-Svc cache
355
+ * on agent initialization, so the first request to these hosts will attempt HTTP/3.
356
+ */
357
+ hints?: Array<Http3Hint>
320
358
  }
321
359
 
322
360
  export interface AgentOptions {
@@ -621,6 +659,17 @@ export declare const enum Http3Congestion {
621
659
  Bbr1 = 'bbr1'
622
660
  }
623
661
 
662
+ /**
663
+ * A hint that HTTP/3 is available at a specific host and port. This pre-populates the Alt-Svc
664
+ * cache so the first request to this host will attempt HTTP/3 immediately.
665
+ */
666
+ export interface Http3Hint {
667
+ /** The hostname (e.g., "example.com"). */
668
+ host: string
669
+ /** The port number (e.g., 443). */
670
+ port: number
671
+ }
672
+
624
673
  /**
625
674
  * Determines the behavior in case the server replies with a redirect status.
626
675
  * One of the following values:
package/index.js CHANGED
@@ -77,8 +77,8 @@ function requireNative() {
77
77
  try {
78
78
  const binding = require('@passcod/faith-android-arm64')
79
79
  const bindingPackageVersion = require('@passcod/faith-android-arm64/package.json').version
80
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
81
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
80
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
81
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
82
82
  }
83
83
  return binding
84
84
  } catch (e) {
@@ -93,8 +93,8 @@ function requireNative() {
93
93
  try {
94
94
  const binding = require('@passcod/faith-android-arm-eabi')
95
95
  const bindingPackageVersion = require('@passcod/faith-android-arm-eabi/package.json').version
96
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
97
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
96
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
97
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
98
98
  }
99
99
  return binding
100
100
  } catch (e) {
@@ -114,8 +114,8 @@ function requireNative() {
114
114
  try {
115
115
  const binding = require('@passcod/faith-win32-x64-gnu')
116
116
  const bindingPackageVersion = require('@passcod/faith-win32-x64-gnu/package.json').version
117
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
118
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
117
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
118
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
119
119
  }
120
120
  return binding
121
121
  } catch (e) {
@@ -130,8 +130,8 @@ function requireNative() {
130
130
  try {
131
131
  const binding = require('@passcod/faith-win32-x64-msvc')
132
132
  const bindingPackageVersion = require('@passcod/faith-win32-x64-msvc/package.json').version
133
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
134
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
133
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
134
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
135
135
  }
136
136
  return binding
137
137
  } catch (e) {
@@ -147,8 +147,8 @@ function requireNative() {
147
147
  try {
148
148
  const binding = require('@passcod/faith-win32-ia32-msvc')
149
149
  const bindingPackageVersion = require('@passcod/faith-win32-ia32-msvc/package.json').version
150
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
151
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
150
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
151
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
152
152
  }
153
153
  return binding
154
154
  } catch (e) {
@@ -163,8 +163,8 @@ function requireNative() {
163
163
  try {
164
164
  const binding = require('@passcod/faith-win32-arm64-msvc')
165
165
  const bindingPackageVersion = require('@passcod/faith-win32-arm64-msvc/package.json').version
166
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
167
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
166
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
167
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
168
168
  }
169
169
  return binding
170
170
  } catch (e) {
@@ -182,8 +182,8 @@ function requireNative() {
182
182
  try {
183
183
  const binding = require('@passcod/faith-darwin-universal')
184
184
  const bindingPackageVersion = require('@passcod/faith-darwin-universal/package.json').version
185
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
186
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
185
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
186
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
187
187
  }
188
188
  return binding
189
189
  } catch (e) {
@@ -198,8 +198,8 @@ function requireNative() {
198
198
  try {
199
199
  const binding = require('@passcod/faith-darwin-x64')
200
200
  const bindingPackageVersion = require('@passcod/faith-darwin-x64/package.json').version
201
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
202
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
201
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
202
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
203
203
  }
204
204
  return binding
205
205
  } catch (e) {
@@ -214,8 +214,8 @@ function requireNative() {
214
214
  try {
215
215
  const binding = require('@passcod/faith-darwin-arm64')
216
216
  const bindingPackageVersion = require('@passcod/faith-darwin-arm64/package.json').version
217
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
218
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
217
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
218
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
219
219
  }
220
220
  return binding
221
221
  } catch (e) {
@@ -234,8 +234,8 @@ function requireNative() {
234
234
  try {
235
235
  const binding = require('@passcod/faith-freebsd-x64')
236
236
  const bindingPackageVersion = require('@passcod/faith-freebsd-x64/package.json').version
237
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
238
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
237
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
238
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
239
239
  }
240
240
  return binding
241
241
  } catch (e) {
@@ -250,8 +250,8 @@ function requireNative() {
250
250
  try {
251
251
  const binding = require('@passcod/faith-freebsd-arm64')
252
252
  const bindingPackageVersion = require('@passcod/faith-freebsd-arm64/package.json').version
253
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
254
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
253
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
254
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
255
255
  }
256
256
  return binding
257
257
  } catch (e) {
@@ -271,8 +271,8 @@ function requireNative() {
271
271
  try {
272
272
  const binding = require('@passcod/faith-linux-x64-musl')
273
273
  const bindingPackageVersion = require('@passcod/faith-linux-x64-musl/package.json').version
274
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
275
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
274
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
275
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
276
276
  }
277
277
  return binding
278
278
  } catch (e) {
@@ -287,8 +287,8 @@ function requireNative() {
287
287
  try {
288
288
  const binding = require('@passcod/faith-linux-x64-gnu')
289
289
  const bindingPackageVersion = require('@passcod/faith-linux-x64-gnu/package.json').version
290
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
291
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
290
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
291
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
292
292
  }
293
293
  return binding
294
294
  } catch (e) {
@@ -305,8 +305,8 @@ function requireNative() {
305
305
  try {
306
306
  const binding = require('@passcod/faith-linux-arm64-musl')
307
307
  const bindingPackageVersion = require('@passcod/faith-linux-arm64-musl/package.json').version
308
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
309
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
308
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
309
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
310
310
  }
311
311
  return binding
312
312
  } catch (e) {
@@ -321,8 +321,8 @@ function requireNative() {
321
321
  try {
322
322
  const binding = require('@passcod/faith-linux-arm64-gnu')
323
323
  const bindingPackageVersion = require('@passcod/faith-linux-arm64-gnu/package.json').version
324
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
325
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
324
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
325
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
326
326
  }
327
327
  return binding
328
328
  } catch (e) {
@@ -339,8 +339,8 @@ function requireNative() {
339
339
  try {
340
340
  const binding = require('@passcod/faith-linux-arm-musleabihf')
341
341
  const bindingPackageVersion = require('@passcod/faith-linux-arm-musleabihf/package.json').version
342
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
343
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
342
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
343
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
344
344
  }
345
345
  return binding
346
346
  } catch (e) {
@@ -355,8 +355,8 @@ function requireNative() {
355
355
  try {
356
356
  const binding = require('@passcod/faith-linux-arm-gnueabihf')
357
357
  const bindingPackageVersion = require('@passcod/faith-linux-arm-gnueabihf/package.json').version
358
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
359
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
358
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
359
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
360
360
  }
361
361
  return binding
362
362
  } catch (e) {
@@ -373,8 +373,8 @@ function requireNative() {
373
373
  try {
374
374
  const binding = require('@passcod/faith-linux-loong64-musl')
375
375
  const bindingPackageVersion = require('@passcod/faith-linux-loong64-musl/package.json').version
376
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
377
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
376
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
377
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
378
378
  }
379
379
  return binding
380
380
  } catch (e) {
@@ -389,8 +389,8 @@ function requireNative() {
389
389
  try {
390
390
  const binding = require('@passcod/faith-linux-loong64-gnu')
391
391
  const bindingPackageVersion = require('@passcod/faith-linux-loong64-gnu/package.json').version
392
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
393
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
392
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
393
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
394
394
  }
395
395
  return binding
396
396
  } catch (e) {
@@ -407,8 +407,8 @@ function requireNative() {
407
407
  try {
408
408
  const binding = require('@passcod/faith-linux-riscv64-musl')
409
409
  const bindingPackageVersion = require('@passcod/faith-linux-riscv64-musl/package.json').version
410
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
411
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
410
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
411
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
412
412
  }
413
413
  return binding
414
414
  } catch (e) {
@@ -423,8 +423,8 @@ function requireNative() {
423
423
  try {
424
424
  const binding = require('@passcod/faith-linux-riscv64-gnu')
425
425
  const bindingPackageVersion = require('@passcod/faith-linux-riscv64-gnu/package.json').version
426
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
427
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
426
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
427
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
428
428
  }
429
429
  return binding
430
430
  } catch (e) {
@@ -440,8 +440,8 @@ function requireNative() {
440
440
  try {
441
441
  const binding = require('@passcod/faith-linux-ppc64-gnu')
442
442
  const bindingPackageVersion = require('@passcod/faith-linux-ppc64-gnu/package.json').version
443
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
444
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
443
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
444
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
445
445
  }
446
446
  return binding
447
447
  } catch (e) {
@@ -456,8 +456,8 @@ function requireNative() {
456
456
  try {
457
457
  const binding = require('@passcod/faith-linux-s390x-gnu')
458
458
  const bindingPackageVersion = require('@passcod/faith-linux-s390x-gnu/package.json').version
459
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
460
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
459
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
460
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
461
461
  }
462
462
  return binding
463
463
  } catch (e) {
@@ -476,8 +476,8 @@ function requireNative() {
476
476
  try {
477
477
  const binding = require('@passcod/faith-openharmony-arm64')
478
478
  const bindingPackageVersion = require('@passcod/faith-openharmony-arm64/package.json').version
479
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
480
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
479
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
480
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
481
481
  }
482
482
  return binding
483
483
  } catch (e) {
@@ -492,8 +492,8 @@ function requireNative() {
492
492
  try {
493
493
  const binding = require('@passcod/faith-openharmony-x64')
494
494
  const bindingPackageVersion = require('@passcod/faith-openharmony-x64/package.json').version
495
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
496
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
495
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
496
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
497
497
  }
498
498
  return binding
499
499
  } catch (e) {
@@ -508,8 +508,8 @@ function requireNative() {
508
508
  try {
509
509
  const binding = require('@passcod/faith-openharmony-arm')
510
510
  const bindingPackageVersion = require('@passcod/faith-openharmony-arm/package.json').version
511
- if (bindingPackageVersion !== '0.0.7' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
512
- throw new Error(`Native binding package version mismatch, expected 0.0.7 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
511
+ if (bindingPackageVersion !== '0.0.9' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
512
+ throw new Error(`Native binding package version mismatch, expected 0.0.9 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
513
513
  }
514
514
  return binding
515
515
  } catch (e) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@passcod/faith",
3
- "version": "0.0.7",
3
+ "version": "0.0.9",
4
4
  "description": "fáith: a Rust-powered fetch",
5
5
  "repository": "https://github.com/passcod/faith",
6
6
  "author": {
@@ -70,17 +70,17 @@
70
70
  "node": ">= 20"
71
71
  },
72
72
  "optionalDependencies": {
73
- "@passcod/faith-darwin-arm64": "0.0.7",
74
- "@passcod/faith-android-arm64": "0.0.7",
75
- "@passcod/faith-win32-arm64-msvc": "0.0.7",
76
- "@passcod/faith-linux-arm64-gnu": "0.0.7",
77
- "@passcod/faith-linux-arm64-musl": "0.0.7",
78
- "@passcod/faith-android-arm-eabi": "0.0.7",
79
- "@passcod/faith-linux-arm-gnueabihf": "0.0.7",
80
- "@passcod/faith-darwin-x64": "0.0.7",
81
- "@passcod/faith-win32-x64-msvc": "0.0.7",
82
- "@passcod/faith-freebsd-x64": "0.0.7",
83
- "@passcod/faith-linux-x64-gnu": "0.0.7",
84
- "@passcod/faith-linux-x64-musl": "0.0.7"
73
+ "@passcod/faith-darwin-arm64": "0.0.9",
74
+ "@passcod/faith-android-arm64": "0.0.9",
75
+ "@passcod/faith-win32-arm64-msvc": "0.0.9",
76
+ "@passcod/faith-linux-arm64-gnu": "0.0.9",
77
+ "@passcod/faith-linux-arm64-musl": "0.0.9",
78
+ "@passcod/faith-android-arm-eabi": "0.0.9",
79
+ "@passcod/faith-linux-arm-gnueabihf": "0.0.9",
80
+ "@passcod/faith-darwin-x64": "0.0.9",
81
+ "@passcod/faith-win32-x64-msvc": "0.0.9",
82
+ "@passcod/faith-freebsd-x64": "0.0.9",
83
+ "@passcod/faith-linux-x64-gnu": "0.0.9",
84
+ "@passcod/faith-linux-x64-musl": "0.0.9"
85
85
  }
86
86
  }
package/wrapper.d.ts CHANGED
@@ -274,6 +274,30 @@ export class Response {
274
274
  */
275
275
  readonly body: ReadableStream<Uint8Array> | null;
276
276
 
277
+ /**
278
+ * The `trailers()` read-only property of the `Response` interface returns a promise that
279
+ * resolves to either `null` or a `Headers` structure that contains the HTTP/2 or /3 trailing
280
+ * headers.
281
+ *
282
+ * This was once in the spec but was removed as it wasn't implemented by any browser.
283
+ *
284
+ * Note that this will never resolve if you don't also consume the body in some way.
285
+ */
286
+ readonly trailers: Promise<Headers | null>;
287
+
288
+ /**
289
+ * Discard the response body, releasing the connection back to the pool.
290
+ *
291
+ * This is useful when you don't need the body but want to ensure the connection
292
+ * can be reused for subsequent requests. If you don't call this and don't consume
293
+ * the body, the connection may be held open until the response is garbage collected.
294
+ *
295
+ * This is custom to Fáith.
296
+ *
297
+ * @returns {Promise<void>} Resolves when the body has been fully discarded
298
+ */
299
+ discard(): Promise<void>;
300
+
277
301
  /**
278
302
  * The `text()` method of the `Response` interface takes a `Response` stream and reads it to
279
303
  * completion. It returns a promise that resolves with a `String`. The response is always decoded
@@ -322,16 +346,6 @@ export class Response {
322
346
  */
323
347
  formData(): Promise<FormData>;
324
348
 
325
- /**
326
- * The `trailers()` method of the `Response` interface returns a promise that resolves to either
327
- * `null` or a `Headers` structure that contains the HTTP/2 or /3 trailing headers.
328
- *
329
- * This was once in the spec as a getter but was removed as it wasn't implemented by any browser.
330
- *
331
- * Note that this will never resolve if you don't also consume the body in some way.
332
- */
333
- trailers(): Promise<Headers | null>;
334
-
335
349
  /**
336
350
  * The `clone()` method of the `Response` interface creates a clone of a response object, identical
337
351
  * in every way, but stored in a different variable.
package/wrapper.js CHANGED
@@ -119,15 +119,6 @@ class Response {
119
119
  throw new Error("not supported");
120
120
  }
121
121
 
122
- /**
123
- * Discard the response body, releasing the connection back to the pool.
124
- *
125
- * This is useful when you don't need the body but want to ensure the connection
126
- * can be reused for subsequent requests. If you don't call this and don't consume
127
- * the body, the connection may be held open until the response is garbage collected.
128
- *
129
- * @returns {Promise<void>} Resolves when the body has been fully discarded
130
- */
131
122
  async discard() {
132
123
  return await this.#nativeResponse.discard();
133
124
  }