@mswjs/interceptors 0.38.5 → 0.38.7

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 (60) hide show
  1. package/lib/browser/{chunk-CNX33NZA.mjs → chunk-3RXCRGL2.mjs} +4 -3
  2. package/lib/browser/{chunk-CNX33NZA.mjs.map → chunk-3RXCRGL2.mjs.map} +1 -1
  3. package/lib/browser/{chunk-SKG3GP7X.mjs → chunk-ARPHZXGT.mjs} +2 -2
  4. package/lib/browser/{chunk-O2RCNIMR.js → chunk-L4DRUEKJ.js} +8 -8
  5. package/lib/browser/{chunk-UY4VLZVB.js → chunk-OTQFOPZM.js} +10 -10
  6. package/lib/browser/{chunk-7RPAMWJ6.mjs → chunk-QKSBFQDK.mjs} +2 -2
  7. package/lib/browser/{chunk-MSUVVHIG.js → chunk-T7TBRNJZ.js} +4 -3
  8. package/lib/browser/chunk-T7TBRNJZ.js.map +1 -0
  9. package/lib/browser/index.js +2 -2
  10. package/lib/browser/index.mjs +1 -1
  11. package/lib/browser/interceptors/XMLHttpRequest/index.js +3 -3
  12. package/lib/browser/interceptors/XMLHttpRequest/index.mjs +2 -2
  13. package/lib/browser/interceptors/fetch/index.js +3 -3
  14. package/lib/browser/interceptors/fetch/index.mjs +2 -2
  15. package/lib/browser/presets/browser.js +5 -5
  16. package/lib/browser/presets/browser.mjs +3 -3
  17. package/lib/node/RemoteHttpInterceptor.js +11 -11
  18. package/lib/node/RemoteHttpInterceptor.mjs +5 -5
  19. package/lib/node/{chunk-R7MWIVYW.js → chunk-4WG2AM2T.js} +7 -7
  20. package/lib/node/{chunk-DLID3GDG.js → chunk-A7U44ARP.js} +4 -3
  21. package/lib/node/chunk-A7U44ARP.js.map +1 -0
  22. package/lib/node/{chunk-3HLZLASJ.mjs → chunk-EADPZWWI.mjs} +2 -2
  23. package/lib/node/{chunk-3TXENUZY.mjs → chunk-GL6JCI7E.mjs} +2 -2
  24. package/lib/node/{chunk-FHLAZ57F.mjs → chunk-GLGFOTGJ.mjs} +31 -3
  25. package/lib/node/chunk-GLGFOTGJ.mjs.map +1 -0
  26. package/lib/node/{chunk-YM42IU6M.mjs → chunk-IHJSPMYM.mjs} +4 -3
  27. package/lib/node/{chunk-YM42IU6M.mjs.map → chunk-IHJSPMYM.mjs.map} +1 -1
  28. package/lib/node/{chunk-MCB574K6.js → chunk-R6JVCM7X.js} +3 -3
  29. package/lib/node/{chunk-TBU3WLO3.mjs → chunk-RC2XPCC4.mjs} +2 -2
  30. package/lib/node/{chunk-K4I5GNXU.js → chunk-YAIEISAR.js} +8 -8
  31. package/lib/node/{chunk-RA7KLLRD.js → chunk-ZAIODWHA.js} +41 -13
  32. package/lib/node/chunk-ZAIODWHA.js.map +1 -0
  33. package/lib/node/index.js +3 -3
  34. package/lib/node/index.mjs +2 -2
  35. package/lib/node/interceptors/ClientRequest/index.js +3 -3
  36. package/lib/node/interceptors/ClientRequest/index.mjs +2 -2
  37. package/lib/node/interceptors/XMLHttpRequest/index.js +3 -3
  38. package/lib/node/interceptors/XMLHttpRequest/index.mjs +2 -2
  39. package/lib/node/interceptors/fetch/index.js +3 -3
  40. package/lib/node/interceptors/fetch/index.mjs +2 -2
  41. package/lib/node/presets/node.js +7 -7
  42. package/lib/node/presets/node.mjs +4 -4
  43. package/package.json +2 -2
  44. package/src/interceptors/ClientRequest/MockHttpSocket.ts +14 -0
  45. package/src/interceptors/ClientRequest/index.ts +28 -1
  46. package/src/utils/fetchUtils.ts +2 -1
  47. package/lib/browser/chunk-MSUVVHIG.js.map +0 -1
  48. package/lib/node/chunk-DLID3GDG.js.map +0 -1
  49. package/lib/node/chunk-FHLAZ57F.mjs.map +0 -1
  50. package/lib/node/chunk-RA7KLLRD.js.map +0 -1
  51. /package/lib/browser/{chunk-SKG3GP7X.mjs.map → chunk-ARPHZXGT.mjs.map} +0 -0
  52. /package/lib/browser/{chunk-O2RCNIMR.js.map → chunk-L4DRUEKJ.js.map} +0 -0
  53. /package/lib/browser/{chunk-UY4VLZVB.js.map → chunk-OTQFOPZM.js.map} +0 -0
  54. /package/lib/browser/{chunk-7RPAMWJ6.mjs.map → chunk-QKSBFQDK.mjs.map} +0 -0
  55. /package/lib/node/{chunk-R7MWIVYW.js.map → chunk-4WG2AM2T.js.map} +0 -0
  56. /package/lib/node/{chunk-3HLZLASJ.mjs.map → chunk-EADPZWWI.mjs.map} +0 -0
  57. /package/lib/node/{chunk-3TXENUZY.mjs.map → chunk-GL6JCI7E.mjs.map} +0 -0
  58. /package/lib/node/{chunk-MCB574K6.js.map → chunk-R6JVCM7X.js.map} +0 -0
  59. /package/lib/node/{chunk-TBU3WLO3.mjs.map → chunk-RC2XPCC4.mjs.map} +0 -0
  60. /package/lib/node/{chunk-K4I5GNXU.js.map → chunk-YAIEISAR.js.map} +0 -0
@@ -70,8 +70,9 @@ var _FetchResponse = class extends Response {
70
70
  const safeStatus = _FetchResponse.isConfigurableStatusCode(status) ? status : 200;
71
71
  const finalBody = _FetchResponse.isResponseWithBody(status) ? body : null;
72
72
  super(finalBody, {
73
- ...init,
74
- status: safeStatus
73
+ status: safeStatus,
74
+ statusText: init.statusText,
75
+ headers: init.headers
75
76
  });
76
77
  if (status !== safeStatus) {
77
78
  const state = getValueBySymbol("state", this);
@@ -113,4 +114,4 @@ export {
113
114
  getRawRequest,
114
115
  setRawRequest
115
116
  };
116
- //# sourceMappingURL=chunk-CNX33NZA.mjs.map
117
+ //# sourceMappingURL=chunk-3RXCRGL2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/glossary.ts","../../src/utils/canParseUrl.ts","../../src/utils/getValueBySymbol.ts","../../src/utils/fetchUtils.ts","../../src/getRawRequest.ts"],"sourcesContent":["import type { RequestController } from './RequestController'\n\nexport const IS_PATCHED_MODULE: unique symbol = Symbol('isPatchedModule')\n\n/**\n * @note Export `RequestController` as a type only.\n * It's never meant to be created in the userland.\n */\nexport type { RequestController }\n\nexport type RequestCredentials = 'omit' | 'include' | 'same-origin'\n\nexport type HttpRequestEventMap = {\n request: [\n args: {\n request: Request\n requestId: string\n controller: RequestController\n }\n ]\n response: [\n args: {\n response: Response\n isMockedResponse: boolean\n request: Request\n requestId: string\n }\n ]\n unhandledException: [\n args: {\n error: unknown\n request: Request\n requestId: string\n controller: RequestController\n }\n ]\n}\n","/**\n * Returns a boolean indicating whether the given URL string\n * can be parsed into a `URL` instance.\n * A substitute for `URL.canParse()` for Node.js 18.\n */\nexport function canParseUrl(url: string): boolean {\n try {\n new URL(url)\n return true\n } catch (_error) {\n return false\n }\n}\n","/**\n * Returns the value behind the symbol with the given name.\n */\nexport function getValueBySymbol<T>(\n symbolName: string,\n source: object\n): T | undefined {\n const ownSymbols = Object.getOwnPropertySymbols(source)\n\n const symbol = ownSymbols.find((symbol) => {\n return symbol.description === symbolName\n })\n\n if (symbol) {\n return Reflect.get(source, symbol)\n }\n\n return\n}\n","import { canParseUrl } from './canParseUrl'\nimport { getValueBySymbol } from './getValueBySymbol'\n\nexport interface FetchResponseInit extends ResponseInit {\n url?: string\n}\n\ninterface UndiciFetchInternalState {\n aborted: boolean\n rangeRequested: boolean\n timingAllowPassed: boolean\n requestIncludesCredentials: boolean\n type: ResponseType\n status: number\n statusText: string\n timingInfo: unknown\n cacheState: unknown\n headersList: Record<symbol, Map<string, unknown>>\n urlList: Array<URL>\n body?: {\n stream: ReadableStream\n source: unknown\n length: number\n }\n}\n\nexport class FetchResponse extends Response {\n /**\n * Response status codes for responses that cannot have body.\n * @see https://fetch.spec.whatwg.org/#statuses\n */\n static readonly STATUS_CODES_WITHOUT_BODY = [101, 103, 204, 205, 304]\n\n static readonly STATUS_CODES_WITH_REDIRECT = [301, 302, 303, 307, 308]\n\n static isConfigurableStatusCode(status: number): boolean {\n return status >= 200 && status <= 599\n }\n\n static isRedirectResponse(status: number): boolean {\n return FetchResponse.STATUS_CODES_WITH_REDIRECT.includes(status)\n }\n\n /**\n * Returns a boolean indicating whether the given response status\n * code represents a response that can have a body.\n */\n static isResponseWithBody(status: number): boolean {\n return !FetchResponse.STATUS_CODES_WITHOUT_BODY.includes(status)\n }\n\n static setUrl(url: string | undefined, response: Response): void {\n if (!url || url === 'about:' || !canParseUrl(url)) {\n return\n }\n\n const state = getValueBySymbol<UndiciFetchInternalState>('state', response)\n\n if (state) {\n // In Undici, push the URL to the internal list of URLs.\n // This will respect the `response.url` getter logic correctly.\n state.urlList.push(new URL(url))\n } else {\n // In other libraries, redefine the `url` property directly.\n Object.defineProperty(response, 'url', {\n value: url,\n enumerable: true,\n configurable: true,\n writable: false,\n })\n }\n }\n\n /**\n * Parses the given raw HTTP headers into a Fetch API `Headers` instance.\n */\n static parseRawHeaders(rawHeaders: Array<string>): Headers {\n const headers = new Headers()\n for (let line = 0; line < rawHeaders.length; line += 2) {\n headers.append(rawHeaders[line], rawHeaders[line + 1])\n }\n return headers\n }\n\n constructor(body?: BodyInit | null, init: FetchResponseInit = {}) {\n const status = init.status ?? 200\n const safeStatus = FetchResponse.isConfigurableStatusCode(status)\n ? status\n : 200\n const finalBody = FetchResponse.isResponseWithBody(status) ? body : null\n\n super(finalBody, {\n ...init,\n status: safeStatus,\n })\n\n if (status !== safeStatus) {\n /**\n * @note Undici keeps an internal \"Symbol(state)\" that holds\n * the actual value of response status. Update that in Node.js.\n */\n const state = getValueBySymbol<UndiciFetchInternalState>('state', this)\n\n if (state) {\n state.status = status\n } else {\n Object.defineProperty(this, 'status', {\n value: status,\n enumerable: true,\n configurable: true,\n writable: false,\n })\n }\n }\n\n FetchResponse.setUrl(init.url, this)\n }\n}\n","const kRawRequest = Symbol('kRawRequest')\n\n/**\n * Returns a raw request instance associated with this request.\n *\n * @example\n * interceptor.on('request', ({ request }) => {\n * const rawRequest = getRawRequest(request)\n *\n * if (rawRequest instanceof http.ClientRequest) {\n * console.log(rawRequest.rawHeaders)\n * }\n * })\n */\nexport function getRawRequest(request: Request): unknown | undefined {\n return Reflect.get(request, kRawRequest)\n}\n\nexport function setRawRequest(request: Request, rawRequest: unknown): void {\n Reflect.set(request, kRawRequest, rawRequest)\n}\n"],"mappings":";AAEO,IAAM,oBAAmC,OAAO,iBAAiB;;;ACGjE,SAAS,YAAY,KAAsB;AAChD,MAAI;AACF,QAAI,IAAI,GAAG;AACX,WAAO;AAAA,EACT,SAAS,QAAP;AACA,WAAO;AAAA,EACT;AACF;;;ACTO,SAAS,iBACd,YACA,QACe;AACf,QAAM,aAAa,OAAO,sBAAsB,MAAM;AAEtD,QAAM,SAAS,WAAW,KAAK,CAACA,YAAW;AACzC,WAAOA,QAAO,gBAAgB;AAAA,EAChC,CAAC;AAED,MAAI,QAAQ;AACV,WAAO,QAAQ,IAAI,QAAQ,MAAM;AAAA,EACnC;AAEA;AACF;;;ACQO,IAAM,iBAAN,cAA4B,SAAS;AAAA,EAS1C,OAAO,yBAAyB,QAAyB;AACvD,WAAO,UAAU,OAAO,UAAU;AAAA,EACpC;AAAA,EAEA,OAAO,mBAAmB,QAAyB;AACjD,WAAO,eAAc,2BAA2B,SAAS,MAAM;AAAA,EACjE;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,mBAAmB,QAAyB;AACjD,WAAO,CAAC,eAAc,0BAA0B,SAAS,MAAM;AAAA,EACjE;AAAA,EAEA,OAAO,OAAO,KAAyB,UAA0B;AAC/D,QAAI,CAAC,OAAO,QAAQ,YAAY,CAAC,YAAY,GAAG,GAAG;AACjD;AAAA,IACF;AAEA,UAAM,QAAQ,iBAA2C,SAAS,QAAQ;AAE1E,QAAI,OAAO;AAGT,YAAM,QAAQ,KAAK,IAAI,IAAI,GAAG,CAAC;AAAA,IACjC,OAAO;AAEL,aAAO,eAAe,UAAU,OAAO;AAAA,QACrC,OAAO;AAAA,QACP,YAAY;AAAA,QACZ,cAAc;AAAA,QACd,UAAU;AAAA,MACZ,CAAC;AAAA,IACH;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,OAAO,gBAAgB,YAAoC;AACzD,UAAM,UAAU,IAAI,QAAQ;AAC5B,aAAS,OAAO,GAAG,OAAO,WAAW,QAAQ,QAAQ,GAAG;AACtD,cAAQ,OAAO,WAAW,IAAI,GAAG,WAAW,OAAO,CAAC,CAAC;AAAA,IACvD;AACA,WAAO;AAAA,EACT;AAAA,EAEA,YAAY,MAAwB,OAA0B,CAAC,GAAG;AApFpE;AAqFI,UAAM,UAAS,UAAK,WAAL,YAAe;AAC9B,UAAM,aAAa,eAAc,yBAAyB,MAAM,IAC5D,SACA;AACJ,UAAM,YAAY,eAAc,mBAAmB,MAAM,IAAI,OAAO;AAEpE,UAAM,WAAW;AAAA,MACf,GAAG;AAAA,MACH,QAAQ;AAAA,IACV,CAAC;AAED,QAAI,WAAW,YAAY;AAKzB,YAAM,QAAQ,iBAA2C,SAAS,IAAI;AAEtE,UAAI,OAAO;AACT,cAAM,SAAS;AAAA,MACjB,OAAO;AACL,eAAO,eAAe,MAAM,UAAU;AAAA,UACpC,OAAO;AAAA,UACP,YAAY;AAAA,UACZ,cAAc;AAAA,UACd,UAAU;AAAA,QACZ,CAAC;AAAA,MACH;AAAA,IACF;AAEA,mBAAc,OAAO,KAAK,KAAK,IAAI;AAAA,EACrC;AACF;AA3FO,IAAM,gBAAN;AAAA;AAAA;AAAA;AAAA;AAAM,cAKK,4BAA4B,CAAC,KAAK,KAAK,KAAK,KAAK,GAAG;AALzD,cAOK,6BAA6B,CAAC,KAAK,KAAK,KAAK,KAAK,GAAG;;;ACjCvE,IAAM,cAAc,OAAO,aAAa;AAcjC,SAAS,cAAc,SAAuC;AACnE,SAAO,QAAQ,IAAI,SAAS,WAAW;AACzC;AAEO,SAAS,cAAc,SAAkB,YAA2B;AACzE,UAAQ,IAAI,SAAS,aAAa,UAAU;AAC9C;","names":["symbol"]}
1
+ {"version":3,"sources":["../../src/glossary.ts","../../src/utils/canParseUrl.ts","../../src/utils/getValueBySymbol.ts","../../src/utils/fetchUtils.ts","../../src/getRawRequest.ts"],"sourcesContent":["import type { RequestController } from './RequestController'\n\nexport const IS_PATCHED_MODULE: unique symbol = Symbol('isPatchedModule')\n\n/**\n * @note Export `RequestController` as a type only.\n * It's never meant to be created in the userland.\n */\nexport type { RequestController }\n\nexport type RequestCredentials = 'omit' | 'include' | 'same-origin'\n\nexport type HttpRequestEventMap = {\n request: [\n args: {\n request: Request\n requestId: string\n controller: RequestController\n }\n ]\n response: [\n args: {\n response: Response\n isMockedResponse: boolean\n request: Request\n requestId: string\n }\n ]\n unhandledException: [\n args: {\n error: unknown\n request: Request\n requestId: string\n controller: RequestController\n }\n ]\n}\n","/**\n * Returns a boolean indicating whether the given URL string\n * can be parsed into a `URL` instance.\n * A substitute for `URL.canParse()` for Node.js 18.\n */\nexport function canParseUrl(url: string): boolean {\n try {\n new URL(url)\n return true\n } catch (_error) {\n return false\n }\n}\n","/**\n * Returns the value behind the symbol with the given name.\n */\nexport function getValueBySymbol<T>(\n symbolName: string,\n source: object\n): T | undefined {\n const ownSymbols = Object.getOwnPropertySymbols(source)\n\n const symbol = ownSymbols.find((symbol) => {\n return symbol.description === symbolName\n })\n\n if (symbol) {\n return Reflect.get(source, symbol)\n }\n\n return\n}\n","import { canParseUrl } from './canParseUrl'\nimport { getValueBySymbol } from './getValueBySymbol'\n\nexport interface FetchResponseInit extends ResponseInit {\n url?: string\n}\n\ninterface UndiciFetchInternalState {\n aborted: boolean\n rangeRequested: boolean\n timingAllowPassed: boolean\n requestIncludesCredentials: boolean\n type: ResponseType\n status: number\n statusText: string\n timingInfo: unknown\n cacheState: unknown\n headersList: Record<symbol, Map<string, unknown>>\n urlList: Array<URL>\n body?: {\n stream: ReadableStream\n source: unknown\n length: number\n }\n}\n\nexport class FetchResponse extends Response {\n /**\n * Response status codes for responses that cannot have body.\n * @see https://fetch.spec.whatwg.org/#statuses\n */\n static readonly STATUS_CODES_WITHOUT_BODY = [101, 103, 204, 205, 304]\n\n static readonly STATUS_CODES_WITH_REDIRECT = [301, 302, 303, 307, 308]\n\n static isConfigurableStatusCode(status: number): boolean {\n return status >= 200 && status <= 599\n }\n\n static isRedirectResponse(status: number): boolean {\n return FetchResponse.STATUS_CODES_WITH_REDIRECT.includes(status)\n }\n\n /**\n * Returns a boolean indicating whether the given response status\n * code represents a response that can have a body.\n */\n static isResponseWithBody(status: number): boolean {\n return !FetchResponse.STATUS_CODES_WITHOUT_BODY.includes(status)\n }\n\n static setUrl(url: string | undefined, response: Response): void {\n if (!url || url === 'about:' || !canParseUrl(url)) {\n return\n }\n\n const state = getValueBySymbol<UndiciFetchInternalState>('state', response)\n\n if (state) {\n // In Undici, push the URL to the internal list of URLs.\n // This will respect the `response.url` getter logic correctly.\n state.urlList.push(new URL(url))\n } else {\n // In other libraries, redefine the `url` property directly.\n Object.defineProperty(response, 'url', {\n value: url,\n enumerable: true,\n configurable: true,\n writable: false,\n })\n }\n }\n\n /**\n * Parses the given raw HTTP headers into a Fetch API `Headers` instance.\n */\n static parseRawHeaders(rawHeaders: Array<string>): Headers {\n const headers = new Headers()\n for (let line = 0; line < rawHeaders.length; line += 2) {\n headers.append(rawHeaders[line], rawHeaders[line + 1])\n }\n return headers\n }\n\n constructor(body?: BodyInit | null, init: FetchResponseInit = {}) {\n const status = init.status ?? 200\n const safeStatus = FetchResponse.isConfigurableStatusCode(status)\n ? status\n : 200\n const finalBody = FetchResponse.isResponseWithBody(status) ? body : null\n\n super(finalBody, {\n status: safeStatus,\n statusText: init.statusText,\n headers: init.headers,\n })\n\n if (status !== safeStatus) {\n /**\n * @note Undici keeps an internal \"Symbol(state)\" that holds\n * the actual value of response status. Update that in Node.js.\n */\n const state = getValueBySymbol<UndiciFetchInternalState>('state', this)\n\n if (state) {\n state.status = status\n } else {\n Object.defineProperty(this, 'status', {\n value: status,\n enumerable: true,\n configurable: true,\n writable: false,\n })\n }\n }\n\n FetchResponse.setUrl(init.url, this)\n }\n}\n","const kRawRequest = Symbol('kRawRequest')\n\n/**\n * Returns a raw request instance associated with this request.\n *\n * @example\n * interceptor.on('request', ({ request }) => {\n * const rawRequest = getRawRequest(request)\n *\n * if (rawRequest instanceof http.ClientRequest) {\n * console.log(rawRequest.rawHeaders)\n * }\n * })\n */\nexport function getRawRequest(request: Request): unknown | undefined {\n return Reflect.get(request, kRawRequest)\n}\n\nexport function setRawRequest(request: Request, rawRequest: unknown): void {\n Reflect.set(request, kRawRequest, rawRequest)\n}\n"],"mappings":";AAEO,IAAM,oBAAmC,OAAO,iBAAiB;;;ACGjE,SAAS,YAAY,KAAsB;AAChD,MAAI;AACF,QAAI,IAAI,GAAG;AACX,WAAO;AAAA,EACT,SAAS,QAAP;AACA,WAAO;AAAA,EACT;AACF;;;ACTO,SAAS,iBACd,YACA,QACe;AACf,QAAM,aAAa,OAAO,sBAAsB,MAAM;AAEtD,QAAM,SAAS,WAAW,KAAK,CAACA,YAAW;AACzC,WAAOA,QAAO,gBAAgB;AAAA,EAChC,CAAC;AAED,MAAI,QAAQ;AACV,WAAO,QAAQ,IAAI,QAAQ,MAAM;AAAA,EACnC;AAEA;AACF;;;ACQO,IAAM,iBAAN,cAA4B,SAAS;AAAA,EAS1C,OAAO,yBAAyB,QAAyB;AACvD,WAAO,UAAU,OAAO,UAAU;AAAA,EACpC;AAAA,EAEA,OAAO,mBAAmB,QAAyB;AACjD,WAAO,eAAc,2BAA2B,SAAS,MAAM;AAAA,EACjE;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,mBAAmB,QAAyB;AACjD,WAAO,CAAC,eAAc,0BAA0B,SAAS,MAAM;AAAA,EACjE;AAAA,EAEA,OAAO,OAAO,KAAyB,UAA0B;AAC/D,QAAI,CAAC,OAAO,QAAQ,YAAY,CAAC,YAAY,GAAG,GAAG;AACjD;AAAA,IACF;AAEA,UAAM,QAAQ,iBAA2C,SAAS,QAAQ;AAE1E,QAAI,OAAO;AAGT,YAAM,QAAQ,KAAK,IAAI,IAAI,GAAG,CAAC;AAAA,IACjC,OAAO;AAEL,aAAO,eAAe,UAAU,OAAO;AAAA,QACrC,OAAO;AAAA,QACP,YAAY;AAAA,QACZ,cAAc;AAAA,QACd,UAAU;AAAA,MACZ,CAAC;AAAA,IACH;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,OAAO,gBAAgB,YAAoC;AACzD,UAAM,UAAU,IAAI,QAAQ;AAC5B,aAAS,OAAO,GAAG,OAAO,WAAW,QAAQ,QAAQ,GAAG;AACtD,cAAQ,OAAO,WAAW,IAAI,GAAG,WAAW,OAAO,CAAC,CAAC;AAAA,IACvD;AACA,WAAO;AAAA,EACT;AAAA,EAEA,YAAY,MAAwB,OAA0B,CAAC,GAAG;AApFpE;AAqFI,UAAM,UAAS,UAAK,WAAL,YAAe;AAC9B,UAAM,aAAa,eAAc,yBAAyB,MAAM,IAC5D,SACA;AACJ,UAAM,YAAY,eAAc,mBAAmB,MAAM,IAAI,OAAO;AAEpE,UAAM,WAAW;AAAA,MACf,QAAQ;AAAA,MACR,YAAY,KAAK;AAAA,MACjB,SAAS,KAAK;AAAA,IAChB,CAAC;AAED,QAAI,WAAW,YAAY;AAKzB,YAAM,QAAQ,iBAA2C,SAAS,IAAI;AAEtE,UAAI,OAAO;AACT,cAAM,SAAS;AAAA,MACjB,OAAO;AACL,eAAO,eAAe,MAAM,UAAU;AAAA,UACpC,OAAO;AAAA,UACP,YAAY;AAAA,UACZ,cAAc;AAAA,UACd,UAAU;AAAA,QACZ,CAAC;AAAA,MACH;AAAA,IACF;AAEA,mBAAc,OAAO,KAAK,KAAK,IAAI;AAAA,EACrC;AACF;AA5FO,IAAM,gBAAN;AAAA;AAAA;AAAA;AAAA;AAAM,cAKK,4BAA4B,CAAC,KAAK,KAAK,KAAK,KAAK,GAAG;AALzD,cAOK,6BAA6B,CAAC,KAAK,KAAK,KAAK,KAAK,GAAG;;;ACjCvE,IAAM,cAAc,OAAO,aAAa;AAcjC,SAAS,cAAc,SAAuC;AACnE,SAAO,QAAQ,IAAI,SAAS,WAAW;AACzC;AAEO,SAAS,cAAc,SAAkB,YAA2B;AACzE,UAAQ,IAAI,SAAS,aAAa,UAAU;AAC9C;","names":["symbol"]}
@@ -8,7 +8,7 @@ import {
8
8
  IS_PATCHED_MODULE,
9
9
  canParseUrl,
10
10
  setRawRequest
11
- } from "./chunk-CNX33NZA.mjs";
11
+ } from "./chunk-3RXCRGL2.mjs";
12
12
  import {
13
13
  hasConfigurableGlobal
14
14
  } from "./chunk-TX5GBTFY.mjs";
@@ -288,4 +288,4 @@ FetchInterceptor.symbol = Symbol("fetch");
288
288
  export {
289
289
  FetchInterceptor
290
290
  };
291
- //# sourceMappingURL=chunk-SKG3GP7X.mjs.map
291
+ //# sourceMappingURL=chunk-ARPHZXGT.mjs.map
@@ -11,7 +11,7 @@ var _chunkGTJ35JP4js = require('./chunk-GTJ35JP4.js');
11
11
 
12
12
 
13
13
 
14
- var _chunkMSUVVHIGjs = require('./chunk-MSUVVHIG.js');
14
+ var _chunkT7TBRNJZjs = require('./chunk-T7TBRNJZ.js');
15
15
 
16
16
 
17
17
  var _chunkPFGO5BSMjs = require('./chunk-PFGO5BSM.js');
@@ -207,8 +207,8 @@ function parseJson(data) {
207
207
 
208
208
  // src/interceptors/XMLHttpRequest/utils/createResponse.ts
209
209
  function createResponse(request, body) {
210
- const responseBodyOrNull = _chunkMSUVVHIGjs.FetchResponse.isResponseWithBody(request.status) ? body : null;
211
- return new (0, _chunkMSUVVHIGjs.FetchResponse)(responseBodyOrNull, {
210
+ const responseBodyOrNull = _chunkT7TBRNJZjs.FetchResponse.isResponseWithBody(request.status) ? body : null;
211
+ return new (0, _chunkT7TBRNJZjs.FetchResponse)(responseBodyOrNull, {
212
212
  url: request.responseURL,
213
213
  status: request.status,
214
214
  statusText: request.statusText,
@@ -694,7 +694,7 @@ var XMLHttpRequestController = class {
694
694
  }
695
695
  });
696
696
  define(fetchRequest, "headers", proxyHeaders);
697
- _chunkMSUVVHIGjs.setRawRequest.call(void 0, fetchRequest, this.request);
697
+ _chunkT7TBRNJZjs.setRawRequest.call(void 0, fetchRequest, this.request);
698
698
  this.logger.info("converted request to a Fetch API Request!", fetchRequest);
699
699
  return fetchRequest;
700
700
  }
@@ -809,7 +809,7 @@ var _XMLHttpRequestInterceptor = class extends _chunkTIPR373Rjs.Interceptor {
809
809
  logger.info('patching "XMLHttpRequest" module...');
810
810
  const PureXMLHttpRequest = globalThis.XMLHttpRequest;
811
811
  _outvariant.invariant.call(void 0,
812
- !PureXMLHttpRequest[_chunkMSUVVHIGjs.IS_PATCHED_MODULE],
812
+ !PureXMLHttpRequest[_chunkT7TBRNJZjs.IS_PATCHED_MODULE],
813
813
  'Failed to patch the "XMLHttpRequest" module: already patched.'
814
814
  );
815
815
  globalThis.XMLHttpRequest = createXMLHttpRequestProxy({
@@ -820,13 +820,13 @@ var _XMLHttpRequestInterceptor = class extends _chunkTIPR373Rjs.Interceptor {
820
820
  'native "XMLHttpRequest" module patched!',
821
821
  globalThis.XMLHttpRequest.name
822
822
  );
823
- Object.defineProperty(globalThis.XMLHttpRequest, _chunkMSUVVHIGjs.IS_PATCHED_MODULE, {
823
+ Object.defineProperty(globalThis.XMLHttpRequest, _chunkT7TBRNJZjs.IS_PATCHED_MODULE, {
824
824
  enumerable: true,
825
825
  configurable: true,
826
826
  value: true
827
827
  });
828
828
  this.subscriptions.push(() => {
829
- Object.defineProperty(globalThis.XMLHttpRequest, _chunkMSUVVHIGjs.IS_PATCHED_MODULE, {
829
+ Object.defineProperty(globalThis.XMLHttpRequest, _chunkT7TBRNJZjs.IS_PATCHED_MODULE, {
830
830
  value: void 0
831
831
  });
832
832
  globalThis.XMLHttpRequest = PureXMLHttpRequest;
@@ -843,4 +843,4 @@ XMLHttpRequestInterceptor.interceptorSymbol = Symbol("xhr");
843
843
 
844
844
 
845
845
  exports.XMLHttpRequestInterceptor = XMLHttpRequestInterceptor;
846
- //# sourceMappingURL=chunk-O2RCNIMR.js.map
846
+ //# sourceMappingURL=chunk-L4DRUEKJ.js.map
@@ -8,7 +8,7 @@ var _chunkGTJ35JP4js = require('./chunk-GTJ35JP4.js');
8
8
 
9
9
 
10
10
 
11
- var _chunkMSUVVHIGjs = require('./chunk-MSUVVHIG.js');
11
+ var _chunkT7TBRNJZjs = require('./chunk-T7TBRNJZ.js');
12
12
 
13
13
 
14
14
  var _chunkPFGO5BSMjs = require('./chunk-PFGO5BSM.js');
@@ -172,15 +172,15 @@ var _FetchInterceptor = class extends _chunkTIPR373Rjs.Interceptor {
172
172
  async setup() {
173
173
  const pureFetch = globalThis.fetch;
174
174
  _outvariant.invariant.call(void 0,
175
- !pureFetch[_chunkMSUVVHIGjs.IS_PATCHED_MODULE],
175
+ !pureFetch[_chunkT7TBRNJZjs.IS_PATCHED_MODULE],
176
176
  'Failed to patch the "fetch" module: already patched.'
177
177
  );
178
178
  globalThis.fetch = async (input, init) => {
179
179
  const requestId = _chunkTIPR373Rjs.createRequestId.call(void 0, );
180
- const resolvedInput = typeof input === "string" && typeof location !== "undefined" && !_chunkMSUVVHIGjs.canParseUrl.call(void 0, input) ? new URL(input, location.href) : input;
180
+ const resolvedInput = typeof input === "string" && typeof location !== "undefined" && !_chunkT7TBRNJZjs.canParseUrl.call(void 0, input) ? new URL(input, location.href) : input;
181
181
  const request = new Request(resolvedInput, init);
182
182
  if (input instanceof Request) {
183
- _chunkMSUVVHIGjs.setRawRequest.call(void 0, request, input);
183
+ _chunkT7TBRNJZjs.setRawRequest.call(void 0, request, input);
184
184
  }
185
185
  const responsePromise = new (0, _deferredpromise.DeferredPromise)();
186
186
  const controller = new (0, _chunkGTJ35JP4js.RequestController)(request);
@@ -200,9 +200,9 @@ var _FetchInterceptor = class extends _chunkTIPR373Rjs.Interceptor {
200
200
  rawResponse
201
201
  });
202
202
  const decompressedStream = decompressResponse(rawResponse);
203
- const response = decompressedStream === null ? rawResponse : new (0, _chunkMSUVVHIGjs.FetchResponse)(decompressedStream, rawResponse);
204
- _chunkMSUVVHIGjs.FetchResponse.setUrl(request.url, response);
205
- if (_chunkMSUVVHIGjs.FetchResponse.isRedirectResponse(response.status)) {
203
+ const response = decompressedStream === null ? rawResponse : new (0, _chunkT7TBRNJZjs.FetchResponse)(decompressedStream, rawResponse);
204
+ _chunkT7TBRNJZjs.FetchResponse.setUrl(request.url, response);
205
+ if (_chunkT7TBRNJZjs.FetchResponse.isRedirectResponse(response.status)) {
206
206
  if (request.redirect === "error") {
207
207
  responsePromise.reject(createNetworkError("unexpected redirect"));
208
208
  return;
@@ -265,13 +265,13 @@ var _FetchInterceptor = class extends _chunkTIPR373Rjs.Interceptor {
265
265
  return response;
266
266
  });
267
267
  };
268
- Object.defineProperty(globalThis.fetch, _chunkMSUVVHIGjs.IS_PATCHED_MODULE, {
268
+ Object.defineProperty(globalThis.fetch, _chunkT7TBRNJZjs.IS_PATCHED_MODULE, {
269
269
  enumerable: true,
270
270
  configurable: true,
271
271
  value: true
272
272
  });
273
273
  this.subscriptions.push(() => {
274
- Object.defineProperty(globalThis.fetch, _chunkMSUVVHIGjs.IS_PATCHED_MODULE, {
274
+ Object.defineProperty(globalThis.fetch, _chunkT7TBRNJZjs.IS_PATCHED_MODULE, {
275
275
  value: void 0
276
276
  });
277
277
  globalThis.fetch = pureFetch;
@@ -288,4 +288,4 @@ FetchInterceptor.symbol = Symbol("fetch");
288
288
 
289
289
 
290
290
  exports.FetchInterceptor = FetchInterceptor;
291
- //# sourceMappingURL=chunk-UY4VLZVB.js.map
291
+ //# sourceMappingURL=chunk-OTQFOPZM.js.map
@@ -11,7 +11,7 @@ import {
11
11
  FetchResponse,
12
12
  IS_PATCHED_MODULE,
13
13
  setRawRequest
14
- } from "./chunk-CNX33NZA.mjs";
14
+ } from "./chunk-3RXCRGL2.mjs";
15
15
  import {
16
16
  hasConfigurableGlobal
17
17
  } from "./chunk-TX5GBTFY.mjs";
@@ -843,4 +843,4 @@ XMLHttpRequestInterceptor.interceptorSymbol = Symbol("xhr");
843
843
  export {
844
844
  XMLHttpRequestInterceptor
845
845
  };
846
- //# sourceMappingURL=chunk-7RPAMWJ6.mjs.map
846
+ //# sourceMappingURL=chunk-QKSBFQDK.mjs.map
@@ -70,8 +70,9 @@ var _FetchResponse = class extends Response {
70
70
  const safeStatus = _FetchResponse.isConfigurableStatusCode(status) ? status : 200;
71
71
  const finalBody = _FetchResponse.isResponseWithBody(status) ? body : null;
72
72
  super(finalBody, {
73
- ...init,
74
- status: safeStatus
73
+ status: safeStatus,
74
+ statusText: init.statusText,
75
+ headers: init.headers
75
76
  });
76
77
  if (status !== safeStatus) {
77
78
  const state = getValueBySymbol("state", this);
@@ -113,4 +114,4 @@ function setRawRequest(request, rawRequest) {
113
114
 
114
115
 
115
116
  exports.IS_PATCHED_MODULE = IS_PATCHED_MODULE; exports.canParseUrl = canParseUrl; exports.FetchResponse = FetchResponse; exports.getRawRequest = getRawRequest; exports.setRawRequest = setRawRequest;
116
- //# sourceMappingURL=chunk-MSUVVHIG.js.map
117
+ //# sourceMappingURL=chunk-T7TBRNJZ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/glossary.ts","../../src/utils/canParseUrl.ts","../../src/utils/getValueBySymbol.ts","../../src/utils/fetchUtils.ts","../../src/getRawRequest.ts"],"names":["symbol"],"mappings":";AAEO,IAAM,oBAAmC,OAAO,iBAAiB;;;ACGjE,SAAS,YAAY,KAAsB;AAChD,MAAI;AACF,QAAI,IAAI,GAAG;AACX,WAAO;AAAA,EACT,SAAS,QAAP;AACA,WAAO;AAAA,EACT;AACF;;;ACTO,SAAS,iBACd,YACA,QACe;AACf,QAAM,aAAa,OAAO,sBAAsB,MAAM;AAEtD,QAAM,SAAS,WAAW,KAAK,CAACA,YAAW;AACzC,WAAOA,QAAO,gBAAgB;AAAA,EAChC,CAAC;AAED,MAAI,QAAQ;AACV,WAAO,QAAQ,IAAI,QAAQ,MAAM;AAAA,EACnC;AAEA;AACF;;;ACQO,IAAM,iBAAN,cAA4B,SAAS;AAAA,EAS1C,OAAO,yBAAyB,QAAyB;AACvD,WAAO,UAAU,OAAO,UAAU;AAAA,EACpC;AAAA,EAEA,OAAO,mBAAmB,QAAyB;AACjD,WAAO,eAAc,2BAA2B,SAAS,MAAM;AAAA,EACjE;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,mBAAmB,QAAyB;AACjD,WAAO,CAAC,eAAc,0BAA0B,SAAS,MAAM;AAAA,EACjE;AAAA,EAEA,OAAO,OAAO,KAAyB,UAA0B;AAC/D,QAAI,CAAC,OAAO,QAAQ,YAAY,CAAC,YAAY,GAAG,GAAG;AACjD;AAAA,IACF;AAEA,UAAM,QAAQ,iBAA2C,SAAS,QAAQ;AAE1E,QAAI,OAAO;AAGT,YAAM,QAAQ,KAAK,IAAI,IAAI,GAAG,CAAC;AAAA,IACjC,OAAO;AAEL,aAAO,eAAe,UAAU,OAAO;AAAA,QACrC,OAAO;AAAA,QACP,YAAY;AAAA,QACZ,cAAc;AAAA,QACd,UAAU;AAAA,MACZ,CAAC;AAAA,IACH;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,OAAO,gBAAgB,YAAoC;AACzD,UAAM,UAAU,IAAI,QAAQ;AAC5B,aAAS,OAAO,GAAG,OAAO,WAAW,QAAQ,QAAQ,GAAG;AACtD,cAAQ,OAAO,WAAW,IAAI,GAAG,WAAW,OAAO,CAAC,CAAC;AAAA,IACvD;AACA,WAAO;AAAA,EACT;AAAA,EAEA,YAAY,MAAwB,OAA0B,CAAC,GAAG;AApFpE;AAqFI,UAAM,UAAS,UAAK,WAAL,YAAe;AAC9B,UAAM,aAAa,eAAc,yBAAyB,MAAM,IAC5D,SACA;AACJ,UAAM,YAAY,eAAc,mBAAmB,MAAM,IAAI,OAAO;AAEpE,UAAM,WAAW;AAAA,MACf,QAAQ;AAAA,MACR,YAAY,KAAK;AAAA,MACjB,SAAS,KAAK;AAAA,IAChB,CAAC;AAED,QAAI,WAAW,YAAY;AAKzB,YAAM,QAAQ,iBAA2C,SAAS,IAAI;AAEtE,UAAI,OAAO;AACT,cAAM,SAAS;AAAA,MACjB,OAAO;AACL,eAAO,eAAe,MAAM,UAAU;AAAA,UACpC,OAAO;AAAA,UACP,YAAY;AAAA,UACZ,cAAc;AAAA,UACd,UAAU;AAAA,QACZ,CAAC;AAAA,MACH;AAAA,IACF;AAEA,mBAAc,OAAO,KAAK,KAAK,IAAI;AAAA,EACrC;AACF;AA5FO,IAAM,gBAAN;AAAA;AAAA;AAAA;AAAA;AAAM,cAKK,4BAA4B,CAAC,KAAK,KAAK,KAAK,KAAK,GAAG;AALzD,cAOK,6BAA6B,CAAC,KAAK,KAAK,KAAK,KAAK,GAAG;;;ACjCvE,IAAM,cAAc,OAAO,aAAa;AAcjC,SAAS,cAAc,SAAuC;AACnE,SAAO,QAAQ,IAAI,SAAS,WAAW;AACzC;AAEO,SAAS,cAAc,SAAkB,YAA2B;AACzE,UAAQ,IAAI,SAAS,aAAa,UAAU;AAC9C","sourcesContent":["import type { RequestController } from './RequestController'\n\nexport const IS_PATCHED_MODULE: unique symbol = Symbol('isPatchedModule')\n\n/**\n * @note Export `RequestController` as a type only.\n * It's never meant to be created in the userland.\n */\nexport type { RequestController }\n\nexport type RequestCredentials = 'omit' | 'include' | 'same-origin'\n\nexport type HttpRequestEventMap = {\n request: [\n args: {\n request: Request\n requestId: string\n controller: RequestController\n }\n ]\n response: [\n args: {\n response: Response\n isMockedResponse: boolean\n request: Request\n requestId: string\n }\n ]\n unhandledException: [\n args: {\n error: unknown\n request: Request\n requestId: string\n controller: RequestController\n }\n ]\n}\n","/**\n * Returns a boolean indicating whether the given URL string\n * can be parsed into a `URL` instance.\n * A substitute for `URL.canParse()` for Node.js 18.\n */\nexport function canParseUrl(url: string): boolean {\n try {\n new URL(url)\n return true\n } catch (_error) {\n return false\n }\n}\n","/**\n * Returns the value behind the symbol with the given name.\n */\nexport function getValueBySymbol<T>(\n symbolName: string,\n source: object\n): T | undefined {\n const ownSymbols = Object.getOwnPropertySymbols(source)\n\n const symbol = ownSymbols.find((symbol) => {\n return symbol.description === symbolName\n })\n\n if (symbol) {\n return Reflect.get(source, symbol)\n }\n\n return\n}\n","import { canParseUrl } from './canParseUrl'\nimport { getValueBySymbol } from './getValueBySymbol'\n\nexport interface FetchResponseInit extends ResponseInit {\n url?: string\n}\n\ninterface UndiciFetchInternalState {\n aborted: boolean\n rangeRequested: boolean\n timingAllowPassed: boolean\n requestIncludesCredentials: boolean\n type: ResponseType\n status: number\n statusText: string\n timingInfo: unknown\n cacheState: unknown\n headersList: Record<symbol, Map<string, unknown>>\n urlList: Array<URL>\n body?: {\n stream: ReadableStream\n source: unknown\n length: number\n }\n}\n\nexport class FetchResponse extends Response {\n /**\n * Response status codes for responses that cannot have body.\n * @see https://fetch.spec.whatwg.org/#statuses\n */\n static readonly STATUS_CODES_WITHOUT_BODY = [101, 103, 204, 205, 304]\n\n static readonly STATUS_CODES_WITH_REDIRECT = [301, 302, 303, 307, 308]\n\n static isConfigurableStatusCode(status: number): boolean {\n return status >= 200 && status <= 599\n }\n\n static isRedirectResponse(status: number): boolean {\n return FetchResponse.STATUS_CODES_WITH_REDIRECT.includes(status)\n }\n\n /**\n * Returns a boolean indicating whether the given response status\n * code represents a response that can have a body.\n */\n static isResponseWithBody(status: number): boolean {\n return !FetchResponse.STATUS_CODES_WITHOUT_BODY.includes(status)\n }\n\n static setUrl(url: string | undefined, response: Response): void {\n if (!url || url === 'about:' || !canParseUrl(url)) {\n return\n }\n\n const state = getValueBySymbol<UndiciFetchInternalState>('state', response)\n\n if (state) {\n // In Undici, push the URL to the internal list of URLs.\n // This will respect the `response.url` getter logic correctly.\n state.urlList.push(new URL(url))\n } else {\n // In other libraries, redefine the `url` property directly.\n Object.defineProperty(response, 'url', {\n value: url,\n enumerable: true,\n configurable: true,\n writable: false,\n })\n }\n }\n\n /**\n * Parses the given raw HTTP headers into a Fetch API `Headers` instance.\n */\n static parseRawHeaders(rawHeaders: Array<string>): Headers {\n const headers = new Headers()\n for (let line = 0; line < rawHeaders.length; line += 2) {\n headers.append(rawHeaders[line], rawHeaders[line + 1])\n }\n return headers\n }\n\n constructor(body?: BodyInit | null, init: FetchResponseInit = {}) {\n const status = init.status ?? 200\n const safeStatus = FetchResponse.isConfigurableStatusCode(status)\n ? status\n : 200\n const finalBody = FetchResponse.isResponseWithBody(status) ? body : null\n\n super(finalBody, {\n status: safeStatus,\n statusText: init.statusText,\n headers: init.headers,\n })\n\n if (status !== safeStatus) {\n /**\n * @note Undici keeps an internal \"Symbol(state)\" that holds\n * the actual value of response status. Update that in Node.js.\n */\n const state = getValueBySymbol<UndiciFetchInternalState>('state', this)\n\n if (state) {\n state.status = status\n } else {\n Object.defineProperty(this, 'status', {\n value: status,\n enumerable: true,\n configurable: true,\n writable: false,\n })\n }\n }\n\n FetchResponse.setUrl(init.url, this)\n }\n}\n","const kRawRequest = Symbol('kRawRequest')\n\n/**\n * Returns a raw request instance associated with this request.\n *\n * @example\n * interceptor.on('request', ({ request }) => {\n * const rawRequest = getRawRequest(request)\n *\n * if (rawRequest instanceof http.ClientRequest) {\n * console.log(rawRequest.rawHeaders)\n * }\n * })\n */\nexport function getRawRequest(request: Request): unknown | undefined {\n return Reflect.get(request, kRawRequest)\n}\n\nexport function setRawRequest(request: Request, rawRequest: unknown): void {\n Reflect.set(request, kRawRequest, rawRequest)\n}\n"]}
@@ -6,7 +6,7 @@ var _chunkLK6DILFKjs = require('./chunk-LK6DILFK.js');
6
6
 
7
7
 
8
8
 
9
- var _chunkMSUVVHIGjs = require('./chunk-MSUVVHIG.js');
9
+ var _chunkT7TBRNJZjs = require('./chunk-T7TBRNJZ.js');
10
10
 
11
11
 
12
12
 
@@ -77,5 +77,5 @@ function getCleanUrl(url, isAbsolute = true) {
77
77
 
78
78
 
79
79
 
80
- exports.BatchInterceptor = BatchInterceptor; exports.FetchResponse = _chunkMSUVVHIGjs.FetchResponse; exports.INTERNAL_REQUEST_ID_HEADER_NAME = _chunkTIPR373Rjs.INTERNAL_REQUEST_ID_HEADER_NAME; exports.IS_PATCHED_MODULE = _chunkMSUVVHIGjs.IS_PATCHED_MODULE; exports.Interceptor = _chunkTIPR373Rjs.Interceptor; exports.InterceptorReadyState = _chunkTIPR373Rjs.InterceptorReadyState; exports.createRequestId = _chunkTIPR373Rjs.createRequestId; exports.decodeBuffer = _chunkLK6DILFKjs.decodeBuffer; exports.deleteGlobalSymbol = _chunkTIPR373Rjs.deleteGlobalSymbol; exports.encodeBuffer = _chunkLK6DILFKjs.encodeBuffer; exports.getCleanUrl = getCleanUrl; exports.getGlobalSymbol = _chunkTIPR373Rjs.getGlobalSymbol; exports.getRawRequest = _chunkMSUVVHIGjs.getRawRequest;
80
+ exports.BatchInterceptor = BatchInterceptor; exports.FetchResponse = _chunkT7TBRNJZjs.FetchResponse; exports.INTERNAL_REQUEST_ID_HEADER_NAME = _chunkTIPR373Rjs.INTERNAL_REQUEST_ID_HEADER_NAME; exports.IS_PATCHED_MODULE = _chunkT7TBRNJZjs.IS_PATCHED_MODULE; exports.Interceptor = _chunkTIPR373Rjs.Interceptor; exports.InterceptorReadyState = _chunkTIPR373Rjs.InterceptorReadyState; exports.createRequestId = _chunkTIPR373Rjs.createRequestId; exports.decodeBuffer = _chunkLK6DILFKjs.decodeBuffer; exports.deleteGlobalSymbol = _chunkTIPR373Rjs.deleteGlobalSymbol; exports.encodeBuffer = _chunkLK6DILFKjs.encodeBuffer; exports.getCleanUrl = getCleanUrl; exports.getGlobalSymbol = _chunkTIPR373Rjs.getGlobalSymbol; exports.getRawRequest = _chunkT7TBRNJZjs.getRawRequest;
81
81
  //# sourceMappingURL=index.js.map
@@ -6,7 +6,7 @@ import {
6
6
  FetchResponse,
7
7
  IS_PATCHED_MODULE,
8
8
  getRawRequest
9
- } from "./chunk-CNX33NZA.mjs";
9
+ } from "./chunk-3RXCRGL2.mjs";
10
10
  import {
11
11
  INTERNAL_REQUEST_ID_HEADER_NAME,
12
12
  Interceptor,
@@ -1,12 +1,12 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkO2RCNIMRjs = require('../../chunk-O2RCNIMR.js');
3
+ var _chunkL4DRUEKJjs = require('../../chunk-L4DRUEKJ.js');
4
4
  require('../../chunk-LK6DILFK.js');
5
5
  require('../../chunk-GTJ35JP4.js');
6
- require('../../chunk-MSUVVHIG.js');
6
+ require('../../chunk-T7TBRNJZ.js');
7
7
  require('../../chunk-PFGO5BSM.js');
8
8
  require('../../chunk-TIPR373R.js');
9
9
 
10
10
 
11
- exports.XMLHttpRequestInterceptor = _chunkO2RCNIMRjs.XMLHttpRequestInterceptor;
11
+ exports.XMLHttpRequestInterceptor = _chunkL4DRUEKJjs.XMLHttpRequestInterceptor;
12
12
  //# sourceMappingURL=index.js.map
@@ -1,9 +1,9 @@
1
1
  import {
2
2
  XMLHttpRequestInterceptor
3
- } from "../../chunk-7RPAMWJ6.mjs";
3
+ } from "../../chunk-QKSBFQDK.mjs";
4
4
  import "../../chunk-6HYIRFX2.mjs";
5
5
  import "../../chunk-L37TY7LC.mjs";
6
- import "../../chunk-CNX33NZA.mjs";
6
+ import "../../chunk-3RXCRGL2.mjs";
7
7
  import "../../chunk-TX5GBTFY.mjs";
8
8
  import "../../chunk-QED3Q6Z2.mjs";
9
9
  export {
@@ -1,11 +1,11 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkUY4VLZVBjs = require('../../chunk-UY4VLZVB.js');
3
+ var _chunkOTQFOPZMjs = require('../../chunk-OTQFOPZM.js');
4
4
  require('../../chunk-GTJ35JP4.js');
5
- require('../../chunk-MSUVVHIG.js');
5
+ require('../../chunk-T7TBRNJZ.js');
6
6
  require('../../chunk-PFGO5BSM.js');
7
7
  require('../../chunk-TIPR373R.js');
8
8
 
9
9
 
10
- exports.FetchInterceptor = _chunkUY4VLZVBjs.FetchInterceptor;
10
+ exports.FetchInterceptor = _chunkOTQFOPZMjs.FetchInterceptor;
11
11
  //# sourceMappingURL=index.js.map
@@ -1,8 +1,8 @@
1
1
  import {
2
2
  FetchInterceptor
3
- } from "../../chunk-SKG3GP7X.mjs";
3
+ } from "../../chunk-ARPHZXGT.mjs";
4
4
  import "../../chunk-L37TY7LC.mjs";
5
- import "../../chunk-CNX33NZA.mjs";
5
+ import "../../chunk-3RXCRGL2.mjs";
6
6
  import "../../chunk-TX5GBTFY.mjs";
7
7
  import "../../chunk-QED3Q6Z2.mjs";
8
8
  export {
@@ -1,19 +1,19 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkO2RCNIMRjs = require('../chunk-O2RCNIMR.js');
3
+ var _chunkL4DRUEKJjs = require('../chunk-L4DRUEKJ.js');
4
4
  require('../chunk-LK6DILFK.js');
5
5
 
6
6
 
7
- var _chunkUY4VLZVBjs = require('../chunk-UY4VLZVB.js');
7
+ var _chunkOTQFOPZMjs = require('../chunk-OTQFOPZM.js');
8
8
  require('../chunk-GTJ35JP4.js');
9
- require('../chunk-MSUVVHIG.js');
9
+ require('../chunk-T7TBRNJZ.js');
10
10
  require('../chunk-PFGO5BSM.js');
11
11
  require('../chunk-TIPR373R.js');
12
12
 
13
13
  // src/presets/browser.ts
14
14
  var browser_default = [
15
- new (0, _chunkUY4VLZVBjs.FetchInterceptor)(),
16
- new (0, _chunkO2RCNIMRjs.XMLHttpRequestInterceptor)()
15
+ new (0, _chunkOTQFOPZMjs.FetchInterceptor)(),
16
+ new (0, _chunkL4DRUEKJjs.XMLHttpRequestInterceptor)()
17
17
  ];
18
18
 
19
19
 
@@ -1,12 +1,12 @@
1
1
  import {
2
2
  XMLHttpRequestInterceptor
3
- } from "../chunk-7RPAMWJ6.mjs";
3
+ } from "../chunk-QKSBFQDK.mjs";
4
4
  import "../chunk-6HYIRFX2.mjs";
5
5
  import {
6
6
  FetchInterceptor
7
- } from "../chunk-SKG3GP7X.mjs";
7
+ } from "../chunk-ARPHZXGT.mjs";
8
8
  import "../chunk-L37TY7LC.mjs";
9
- import "../chunk-CNX33NZA.mjs";
9
+ import "../chunk-3RXCRGL2.mjs";
10
10
  import "../chunk-TX5GBTFY.mjs";
11
11
  import "../chunk-QED3Q6Z2.mjs";
12
12
 
@@ -1,17 +1,17 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkMCB574K6js = require('./chunk-MCB574K6.js');
3
+ var _chunkR6JVCM7Xjs = require('./chunk-R6JVCM7X.js');
4
4
 
5
5
 
6
- var _chunkRA7KLLRDjs = require('./chunk-RA7KLLRD.js');
6
+ var _chunkZAIODWHAjs = require('./chunk-ZAIODWHA.js');
7
7
  require('./chunk-4YBV77DG.js');
8
8
 
9
9
 
10
- var _chunkR7MWIVYWjs = require('./chunk-R7MWIVYW.js');
10
+ var _chunk4WG2AM2Tjs = require('./chunk-4WG2AM2T.js');
11
11
  require('./chunk-LK6DILFK.js');
12
12
 
13
13
 
14
- var _chunkK4I5GNXUjs = require('./chunk-K4I5GNXU.js');
14
+ var _chunkYAIEISARjs = require('./chunk-YAIEISAR.js');
15
15
  require('./chunk-PFGO5BSM.js');
16
16
  require('./chunk-73NOP3T5.js');
17
17
 
@@ -21,18 +21,18 @@ var _chunkC2JSMMHYjs = require('./chunk-C2JSMMHY.js');
21
21
 
22
22
 
23
23
 
24
- var _chunkDLID3GDGjs = require('./chunk-DLID3GDG.js');
24
+ var _chunkA7U44ARPjs = require('./chunk-A7U44ARP.js');
25
25
  require('./chunk-SMXZPJEA.js');
26
26
 
27
27
  // src/RemoteHttpInterceptor.ts
28
- var RemoteHttpInterceptor = class extends _chunkMCB574K6js.BatchInterceptor {
28
+ var RemoteHttpInterceptor = class extends _chunkR6JVCM7Xjs.BatchInterceptor {
29
29
  constructor() {
30
30
  super({
31
31
  name: "remote-interceptor",
32
32
  interceptors: [
33
- new (0, _chunkRA7KLLRDjs.ClientRequestInterceptor)(),
34
- new (0, _chunkR7MWIVYWjs.XMLHttpRequestInterceptor)(),
35
- new (0, _chunkK4I5GNXUjs.FetchInterceptor)()
33
+ new (0, _chunkZAIODWHAjs.ClientRequestInterceptor)(),
34
+ new (0, _chunk4WG2AM2Tjs.XMLHttpRequestInterceptor)(),
35
+ new (0, _chunkYAIEISARjs.FetchInterceptor)()
36
36
  ]
37
37
  });
38
38
  }
@@ -67,7 +67,7 @@ var RemoteHttpInterceptor = class extends _chunkMCB574K6js.BatchInterceptor {
67
67
  const responseInit = JSON.parse(
68
68
  serializedResponse
69
69
  );
70
- const mockedResponse = new (0, _chunkDLID3GDGjs.FetchResponse)(responseInit.body, {
70
+ const mockedResponse = new (0, _chunkA7U44ARPjs.FetchResponse)(responseInit.body, {
71
71
  url: request.url,
72
72
  status: responseInit.status,
73
73
  statusText: responseInit.statusText,
@@ -100,7 +100,7 @@ function requestReviver(key, value) {
100
100
  return value;
101
101
  }
102
102
  }
103
- var _RemoteHttpResolver = class extends _chunkDLID3GDGjs.Interceptor {
103
+ var _RemoteHttpResolver = class extends _chunkA7U44ARPjs.Interceptor {
104
104
  constructor(options) {
105
105
  super(_RemoteHttpResolver.symbol);
106
106
  this.process = options.process;
@@ -1,17 +1,17 @@
1
1
  import {
2
2
  BatchInterceptor
3
- } from "./chunk-TBU3WLO3.mjs";
3
+ } from "./chunk-RC2XPCC4.mjs";
4
4
  import {
5
5
  ClientRequestInterceptor
6
- } from "./chunk-FHLAZ57F.mjs";
6
+ } from "./chunk-GLGFOTGJ.mjs";
7
7
  import "./chunk-TJDMZZXE.mjs";
8
8
  import {
9
9
  XMLHttpRequestInterceptor
10
- } from "./chunk-3HLZLASJ.mjs";
10
+ } from "./chunk-EADPZWWI.mjs";
11
11
  import "./chunk-6HYIRFX2.mjs";
12
12
  import {
13
13
  FetchInterceptor
14
- } from "./chunk-3TXENUZY.mjs";
14
+ } from "./chunk-GL6JCI7E.mjs";
15
15
  import "./chunk-TX5GBTFY.mjs";
16
16
  import "./chunk-6YM4PLBI.mjs";
17
17
  import {
@@ -21,7 +21,7 @@ import {
21
21
  import {
22
22
  FetchResponse,
23
23
  Interceptor
24
- } from "./chunk-YM42IU6M.mjs";
24
+ } from "./chunk-IHJSPMYM.mjs";
25
25
  import "./chunk-3GJB4JDF.mjs";
26
26
 
27
27
  // src/RemoteHttpInterceptor.ts
@@ -18,7 +18,7 @@ var _chunkC2JSMMHYjs = require('./chunk-C2JSMMHY.js');
18
18
 
19
19
 
20
20
 
21
- var _chunkDLID3GDGjs = require('./chunk-DLID3GDG.js');
21
+ var _chunkA7U44ARPjs = require('./chunk-A7U44ARP.js');
22
22
 
23
23
 
24
24
  var _chunkSMXZPJEAjs = require('./chunk-SMXZPJEA.js');
@@ -209,8 +209,8 @@ function parseJson(data) {
209
209
 
210
210
  // src/interceptors/XMLHttpRequest/utils/createResponse.ts
211
211
  function createResponse(request, body) {
212
- const responseBodyOrNull = _chunkDLID3GDGjs.FetchResponse.isResponseWithBody(request.status) ? body : null;
213
- return new (0, _chunkDLID3GDGjs.FetchResponse)(responseBodyOrNull, {
212
+ const responseBodyOrNull = _chunkA7U44ARPjs.FetchResponse.isResponseWithBody(request.status) ? body : null;
213
+ return new (0, _chunkA7U44ARPjs.FetchResponse)(responseBodyOrNull, {
214
214
  url: request.responseURL,
215
215
  status: request.status,
216
216
  statusText: request.statusText,
@@ -256,7 +256,7 @@ var XMLHttpRequestController = class {
256
256
  this[kIsRequestHandled] = false;
257
257
  this.events = /* @__PURE__ */ new Map();
258
258
  this.uploadEvents = /* @__PURE__ */ new Map();
259
- this.requestId = _chunkDLID3GDGjs.createRequestId.call(void 0, );
259
+ this.requestId = _chunkA7U44ARPjs.createRequestId.call(void 0, );
260
260
  this.requestHeaders = new Headers();
261
261
  this.responseBuffer = new Uint8Array();
262
262
  this.request = createProxy(initialRequest, {
@@ -338,7 +338,7 @@ var XMLHttpRequestController = class {
338
338
  );
339
339
  if (IS_NODE) {
340
340
  this.request.setRequestHeader(
341
- _chunkDLID3GDGjs.INTERNAL_REQUEST_ID_HEADER_NAME,
341
+ _chunkA7U44ARPjs.INTERNAL_REQUEST_ID_HEADER_NAME,
342
342
  this.requestId
343
343
  );
344
344
  }
@@ -799,7 +799,7 @@ function createXMLHttpRequestProxy({
799
799
  }
800
800
 
801
801
  // src/interceptors/XMLHttpRequest/index.ts
802
- var _XMLHttpRequestInterceptor = class extends _chunkDLID3GDGjs.Interceptor {
802
+ var _XMLHttpRequestInterceptor = class extends _chunkA7U44ARPjs.Interceptor {
803
803
  constructor() {
804
804
  super(_XMLHttpRequestInterceptor.interceptorSymbol);
805
805
  }
@@ -845,4 +845,4 @@ XMLHttpRequestInterceptor.interceptorSymbol = Symbol("xhr");
845
845
 
846
846
 
847
847
  exports.XMLHttpRequestInterceptor = XMLHttpRequestInterceptor;
848
- //# sourceMappingURL=chunk-R7MWIVYW.js.map
848
+ //# sourceMappingURL=chunk-4WG2AM2T.js.map
@@ -227,8 +227,9 @@ var _FetchResponse = class extends Response {
227
227
  const safeStatus = _FetchResponse.isConfigurableStatusCode(status) ? status : 200;
228
228
  const finalBody = _FetchResponse.isResponseWithBody(status) ? body : null;
229
229
  super(finalBody, {
230
- ...init,
231
- status: safeStatus
230
+ status: safeStatus,
231
+ statusText: init.statusText,
232
+ headers: init.headers
232
233
  });
233
234
  if (status !== safeStatus) {
234
235
  const state = getValueBySymbol("state", this);
@@ -264,4 +265,4 @@ FetchResponse.STATUS_CODES_WITH_REDIRECT = [301, 302, 303, 307, 308];
264
265
 
265
266
 
266
267
  exports.INTERNAL_REQUEST_ID_HEADER_NAME = INTERNAL_REQUEST_ID_HEADER_NAME; exports.getGlobalSymbol = getGlobalSymbol; exports.deleteGlobalSymbol = deleteGlobalSymbol; exports.InterceptorReadyState = InterceptorReadyState; exports.Interceptor = Interceptor; exports.createRequestId = createRequestId; exports.canParseUrl = canParseUrl; exports.FetchResponse = FetchResponse;
267
- //# sourceMappingURL=chunk-DLID3GDG.js.map
268
+ //# sourceMappingURL=chunk-A7U44ARP.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/Interceptor.ts","../../src/createRequestId.ts","../../src/utils/canParseUrl.ts","../../src/utils/getValueBySymbol.ts","../../src/utils/fetchUtils.ts"],"names":["InterceptorReadyState","symbol"],"mappings":"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","sourcesContent":["import { Logger } from '@open-draft/logger'\nimport { Emitter, Listener } from 'strict-event-emitter'\n\nexport type InterceptorEventMap = Record<string, any>\nexport type InterceptorSubscription = () => void\n\n/**\n * Request header name to detect when a single request\n * is being handled by nested interceptors (XHR -> ClientRequest).\n * Obscure by design to prevent collisions with user-defined headers.\n * Ideally, come up with the Interceptor-level mechanism for this.\n * @see https://github.com/mswjs/interceptors/issues/378\n */\nexport const INTERNAL_REQUEST_ID_HEADER_NAME =\n 'x-interceptors-internal-request-id'\n\nexport function getGlobalSymbol<V>(symbol: Symbol): V | undefined {\n return (\n // @ts-ignore https://github.com/Microsoft/TypeScript/issues/24587\n globalThis[symbol] || undefined\n )\n}\n\nfunction setGlobalSymbol(symbol: Symbol, value: any): void {\n // @ts-ignore\n globalThis[symbol] = value\n}\n\nexport function deleteGlobalSymbol(symbol: Symbol): void {\n // @ts-ignore\n delete globalThis[symbol]\n}\n\nexport enum InterceptorReadyState {\n INACTIVE = 'INACTIVE',\n APPLYING = 'APPLYING',\n APPLIED = 'APPLIED',\n DISPOSING = 'DISPOSING',\n DISPOSED = 'DISPOSED',\n}\n\nexport type ExtractEventNames<Events extends Record<string, any>> =\n Events extends Record<infer EventName, any> ? EventName : never\n\nexport class Interceptor<Events extends InterceptorEventMap> {\n protected emitter: Emitter<Events>\n protected subscriptions: Array<InterceptorSubscription>\n protected logger: Logger\n\n public readyState: InterceptorReadyState\n\n constructor(private readonly symbol: symbol) {\n this.readyState = InterceptorReadyState.INACTIVE\n\n this.emitter = new Emitter()\n this.subscriptions = []\n this.logger = new Logger(symbol.description!)\n\n // Do not limit the maximum number of listeners\n // so not to limit the maximum amount of parallel events emitted.\n this.emitter.setMaxListeners(0)\n\n this.logger.info('constructing the interceptor...')\n }\n\n /**\n * Determine if this interceptor can be applied\n * in the current environment.\n */\n protected checkEnvironment(): boolean {\n return true\n }\n\n /**\n * Apply this interceptor to the current process.\n * Returns an already running interceptor instance if it's present.\n */\n public apply(): void {\n const logger = this.logger.extend('apply')\n logger.info('applying the interceptor...')\n\n if (this.readyState === InterceptorReadyState.APPLIED) {\n logger.info('intercepted already applied!')\n return\n }\n\n const shouldApply = this.checkEnvironment()\n\n if (!shouldApply) {\n logger.info('the interceptor cannot be applied in this environment!')\n return\n }\n\n this.readyState = InterceptorReadyState.APPLYING\n\n // Whenever applying a new interceptor, check if it hasn't been applied already.\n // This enables to apply the same interceptor multiple times, for example from a different\n // interceptor, only proxying events but keeping the stubs in a single place.\n const runningInstance = this.getInstance()\n\n if (runningInstance) {\n logger.info('found a running instance, reusing...')\n\n // Proxy any listeners you set on this instance to the running instance.\n this.on = (event, listener) => {\n logger.info('proxying the \"%s\" listener', event)\n\n // Add listeners to the running instance so they appear\n // at the top of the event listeners list and are executed first.\n runningInstance.emitter.addListener(event, listener)\n\n // Ensure that once this interceptor instance is disposed,\n // it removes all listeners it has appended to the running interceptor instance.\n this.subscriptions.push(() => {\n runningInstance.emitter.removeListener(event, listener)\n logger.info('removed proxied \"%s\" listener!', event)\n })\n\n return this\n }\n\n this.readyState = InterceptorReadyState.APPLIED\n\n return\n }\n\n logger.info('no running instance found, setting up a new instance...')\n\n // Setup the interceptor.\n this.setup()\n\n // Store the newly applied interceptor instance globally.\n this.setInstance()\n\n this.readyState = InterceptorReadyState.APPLIED\n }\n\n /**\n * Setup the module augments and stubs necessary for this interceptor.\n * This method is not run if there's a running interceptor instance\n * to prevent instantiating an interceptor multiple times.\n */\n protected setup(): void {}\n\n /**\n * Listen to the interceptor's public events.\n */\n public on<EventName extends ExtractEventNames<Events>>(\n event: EventName,\n listener: Listener<Events[EventName]>\n ): this {\n const logger = this.logger.extend('on')\n\n if (\n this.readyState === InterceptorReadyState.DISPOSING ||\n this.readyState === InterceptorReadyState.DISPOSED\n ) {\n logger.info('cannot listen to events, already disposed!')\n return this\n }\n\n logger.info('adding \"%s\" event listener:', event, listener)\n\n this.emitter.on(event, listener)\n return this\n }\n\n public once<EventName extends ExtractEventNames<Events>>(\n event: EventName,\n listener: Listener<Events[EventName]>\n ): this {\n this.emitter.once(event, listener)\n return this\n }\n\n public off<EventName extends ExtractEventNames<Events>>(\n event: EventName,\n listener: Listener<Events[EventName]>\n ): this {\n this.emitter.off(event, listener)\n return this\n }\n\n public removeAllListeners<EventName extends ExtractEventNames<Events>>(\n event?: EventName\n ): this {\n this.emitter.removeAllListeners(event)\n return this\n }\n\n /**\n * Disposes of any side-effects this interceptor has introduced.\n */\n public dispose(): void {\n const logger = this.logger.extend('dispose')\n\n if (this.readyState === InterceptorReadyState.DISPOSED) {\n logger.info('cannot dispose, already disposed!')\n return\n }\n\n logger.info('disposing the interceptor...')\n this.readyState = InterceptorReadyState.DISPOSING\n\n if (!this.getInstance()) {\n logger.info('no interceptors running, skipping dispose...')\n return\n }\n\n // Delete the global symbol as soon as possible,\n // indicating that the interceptor is no longer running.\n this.clearInstance()\n\n logger.info('global symbol deleted:', getGlobalSymbol(this.symbol))\n\n if (this.subscriptions.length > 0) {\n logger.info('disposing of %d subscriptions...', this.subscriptions.length)\n\n for (const dispose of this.subscriptions) {\n dispose()\n }\n\n this.subscriptions = []\n\n logger.info('disposed of all subscriptions!', this.subscriptions.length)\n }\n\n this.emitter.removeAllListeners()\n logger.info('destroyed the listener!')\n\n this.readyState = InterceptorReadyState.DISPOSED\n }\n\n private getInstance(): this | undefined {\n const instance = getGlobalSymbol<this>(this.symbol)\n this.logger.info('retrieved global instance:', instance?.constructor?.name)\n return instance\n }\n\n private setInstance(): void {\n setGlobalSymbol(this.symbol, this)\n this.logger.info('set global instance!', this.symbol.description)\n }\n\n private clearInstance(): void {\n deleteGlobalSymbol(this.symbol)\n this.logger.info('cleared global instance!', this.symbol.description)\n }\n}\n","/**\n * Generate a random ID string to represent a request.\n * @example\n * createRequestId()\n * // \"f774b6c9c600f\"\n */\nexport function createRequestId(): string {\n return Math.random().toString(16).slice(2)\n}\n","/**\n * Returns a boolean indicating whether the given URL string\n * can be parsed into a `URL` instance.\n * A substitute for `URL.canParse()` for Node.js 18.\n */\nexport function canParseUrl(url: string): boolean {\n try {\n new URL(url)\n return true\n } catch (_error) {\n return false\n }\n}\n","/**\n * Returns the value behind the symbol with the given name.\n */\nexport function getValueBySymbol<T>(\n symbolName: string,\n source: object\n): T | undefined {\n const ownSymbols = Object.getOwnPropertySymbols(source)\n\n const symbol = ownSymbols.find((symbol) => {\n return symbol.description === symbolName\n })\n\n if (symbol) {\n return Reflect.get(source, symbol)\n }\n\n return\n}\n","import { canParseUrl } from './canParseUrl'\nimport { getValueBySymbol } from './getValueBySymbol'\n\nexport interface FetchResponseInit extends ResponseInit {\n url?: string\n}\n\ninterface UndiciFetchInternalState {\n aborted: boolean\n rangeRequested: boolean\n timingAllowPassed: boolean\n requestIncludesCredentials: boolean\n type: ResponseType\n status: number\n statusText: string\n timingInfo: unknown\n cacheState: unknown\n headersList: Record<symbol, Map<string, unknown>>\n urlList: Array<URL>\n body?: {\n stream: ReadableStream\n source: unknown\n length: number\n }\n}\n\nexport class FetchResponse extends Response {\n /**\n * Response status codes for responses that cannot have body.\n * @see https://fetch.spec.whatwg.org/#statuses\n */\n static readonly STATUS_CODES_WITHOUT_BODY = [101, 103, 204, 205, 304]\n\n static readonly STATUS_CODES_WITH_REDIRECT = [301, 302, 303, 307, 308]\n\n static isConfigurableStatusCode(status: number): boolean {\n return status >= 200 && status <= 599\n }\n\n static isRedirectResponse(status: number): boolean {\n return FetchResponse.STATUS_CODES_WITH_REDIRECT.includes(status)\n }\n\n /**\n * Returns a boolean indicating whether the given response status\n * code represents a response that can have a body.\n */\n static isResponseWithBody(status: number): boolean {\n return !FetchResponse.STATUS_CODES_WITHOUT_BODY.includes(status)\n }\n\n static setUrl(url: string | undefined, response: Response): void {\n if (!url || url === 'about:' || !canParseUrl(url)) {\n return\n }\n\n const state = getValueBySymbol<UndiciFetchInternalState>('state', response)\n\n if (state) {\n // In Undici, push the URL to the internal list of URLs.\n // This will respect the `response.url` getter logic correctly.\n state.urlList.push(new URL(url))\n } else {\n // In other libraries, redefine the `url` property directly.\n Object.defineProperty(response, 'url', {\n value: url,\n enumerable: true,\n configurable: true,\n writable: false,\n })\n }\n }\n\n /**\n * Parses the given raw HTTP headers into a Fetch API `Headers` instance.\n */\n static parseRawHeaders(rawHeaders: Array<string>): Headers {\n const headers = new Headers()\n for (let line = 0; line < rawHeaders.length; line += 2) {\n headers.append(rawHeaders[line], rawHeaders[line + 1])\n }\n return headers\n }\n\n constructor(body?: BodyInit | null, init: FetchResponseInit = {}) {\n const status = init.status ?? 200\n const safeStatus = FetchResponse.isConfigurableStatusCode(status)\n ? status\n : 200\n const finalBody = FetchResponse.isResponseWithBody(status) ? body : null\n\n super(finalBody, {\n status: safeStatus,\n statusText: init.statusText,\n headers: init.headers,\n })\n\n if (status !== safeStatus) {\n /**\n * @note Undici keeps an internal \"Symbol(state)\" that holds\n * the actual value of response status. Update that in Node.js.\n */\n const state = getValueBySymbol<UndiciFetchInternalState>('state', this)\n\n if (state) {\n state.status = status\n } else {\n Object.defineProperty(this, 'status', {\n value: status,\n enumerable: true,\n configurable: true,\n writable: false,\n })\n }\n }\n\n FetchResponse.setUrl(init.url, this)\n }\n}\n"]}
@@ -18,7 +18,7 @@ import {
18
18
  INTERNAL_REQUEST_ID_HEADER_NAME,
19
19
  Interceptor,
20
20
  createRequestId
21
- } from "./chunk-YM42IU6M.mjs";
21
+ } from "./chunk-IHJSPMYM.mjs";
22
22
  import {
23
23
  setRawRequest
24
24
  } from "./chunk-3GJB4JDF.mjs";
@@ -845,4 +845,4 @@ XMLHttpRequestInterceptor.interceptorSymbol = Symbol("xhr");
845
845
  export {
846
846
  XMLHttpRequestInterceptor
847
847
  };
848
- //# sourceMappingURL=chunk-3HLZLASJ.mjs.map
848
+ //# sourceMappingURL=chunk-EADPZWWI.mjs.map
@@ -14,7 +14,7 @@ import {
14
14
  Interceptor,
15
15
  canParseUrl,
16
16
  createRequestId
17
- } from "./chunk-YM42IU6M.mjs";
17
+ } from "./chunk-IHJSPMYM.mjs";
18
18
  import {
19
19
  setRawRequest
20
20
  } from "./chunk-3GJB4JDF.mjs";
@@ -305,4 +305,4 @@ FetchInterceptor.symbol = Symbol("fetch");
305
305
  export {
306
306
  FetchInterceptor
307
307
  };
308
- //# sourceMappingURL=chunk-3TXENUZY.mjs.map
308
+ //# sourceMappingURL=chunk-GL6JCI7E.mjs.map