@warp-drive/core 5.6.0-alpha.12 → 5.6.0-alpha.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -8,19 +8,6 @@ export { C as CacheHandler } from "./handler-cHghx9Y9.js";
8
8
  import '@ember/debug';
9
9
  import './utils/string.js';
10
10
 
11
- /**
12
- * A basic Fetch Handler which converts a request into a
13
- * `fetch` call presuming the response to be `json`.
14
- *
15
- * ```ts
16
- * import Fetch from '@ember-data/request/fetch';
17
- *
18
- * manager.use([Fetch]);
19
- * ```
20
- *
21
- * @module
22
- */
23
-
24
11
  // Lazily close over fetch to avoid breaking Mirage
25
12
  const _fetch = typeof fetch !== 'undefined' ? (...args) => fetch(...args) : typeof FastBoot !== 'undefined' ? (...args) => FastBoot.require('node-fetch')(...args) : () => {
26
13
  throw new Error('No Fetch Implementation Found');
@@ -40,16 +27,20 @@ const MUTATION_OPS = new Set(['updateRecord', 'createRecord', 'deleteRecord']);
40
27
  const ERROR_STATUS_CODE_FOR = new Map([[400, 'Bad Request'], [401, 'Unauthorized'], [402, 'Payment Required'], [403, 'Forbidden'], [404, 'Not Found'], [405, 'Method Not Allowed'], [406, 'Not Acceptable'], [407, 'Proxy Authentication Required'], [408, 'Request Timeout'], [409, 'Conflict'], [410, 'Gone'], [411, 'Length Required'], [412, 'Precondition Failed'], [413, 'Payload Too Large'], [414, 'URI Too Long'], [415, 'Unsupported Media Type'], [416, 'Range Not Satisfiable'], [417, 'Expectation Failed'], [419, 'Page Expired'], [420, 'Enhance Your Calm'], [421, 'Misdirected Request'], [422, 'Unprocessable Entity'], [423, 'Locked'], [424, 'Failed Dependency'], [425, 'Too Early'], [426, 'Upgrade Required'], [428, 'Precondition Required'], [429, 'Too Many Requests'], [430, 'Request Header Fields Too Large'], [431, 'Request Header Fields Too Large'], [450, 'Blocked By Windows Parental Controls'], [451, 'Unavailable For Legal Reasons'], [500, 'Internal Server Error'], [501, 'Not Implemented'], [502, 'Bad Gateway'], [503, 'Service Unavailable'], [504, 'Gateway Timeout'], [505, 'HTTP Version Not Supported'], [506, 'Variant Also Negotiates'], [507, 'Insufficient Storage'], [508, 'Loop Detected'], [509, 'Bandwidth Limit Exceeded'], [510, 'Not Extended'], [511, 'Network Authentication Required']]);
41
28
 
42
29
  /**
43
- * A basic handler which converts a request into a
30
+ * ```ts
31
+ * import { Fetch } from '@warp-drive/core';
32
+ * ```
33
+ *
34
+ * A basic Fetch Handler which converts a request into a
44
35
  * `fetch` call presuming the response to be `json`.
45
36
  *
46
37
  * ```ts
47
- * import Fetch from '@ember-data/request/fetch';
38
+ * import { RequestManager, Fetch } from '@warp-drive/core';
48
39
  *
49
- * manager.use([Fetch]);
40
+ * const manager = new RequestManager()
41
+ * .use([Fetch]);
50
42
  * ```
51
43
  *
52
- * @class Fetch
53
44
  * @public
54
45
  */
55
46
  const Fetch = {
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/request/-private/fetch.ts","../src/request/-private/manager.ts","../src/index.ts"],"sourcesContent":["/**\n * A basic Fetch Handler which converts a request into a\n * `fetch` call presuming the response to be `json`.\n *\n * ```ts\n * import Fetch from '@ember-data/request/fetch';\n *\n * manager.use([Fetch]);\n * ```\n *\n * @module\n */\n\nimport { DEBUG } from '@warp-drive/core/build-config/env';\nimport { assert } from '@warp-drive/core/build-config/macros';\n\nimport { cloneResponseProperties, type Context } from './context';\nimport type { HttpErrorProps } from './utils';\n\ninterface FastbootRequest extends Request {\n protocol: string;\n host: string;\n}\nexport interface FastBoot {\n require(moduleName: string): unknown;\n isFastBoot: boolean;\n request: FastbootRequest;\n}\n\n// Lazily close over fetch to avoid breaking Mirage\nconst _fetch: typeof fetch =\n typeof fetch !== 'undefined'\n ? (...args) => fetch(...args)\n : typeof FastBoot !== 'undefined'\n ? (...args) => ((FastBoot as FastBoot).require('node-fetch') as typeof fetch)(...args)\n : ((() => {\n throw new Error('No Fetch Implementation Found');\n }) as typeof fetch);\n\n// clones a response in a way that should still\n// allow it to stream\nfunction cloneResponse(response: Response, overrides: Partial<Response>) {\n const props = cloneResponseProperties(response);\n return new Response(response.body, Object.assign(props, overrides));\n}\n\nlet IS_MAYBE_MIRAGE = () => false;\nif (DEBUG) {\n IS_MAYBE_MIRAGE = () =>\n Boolean(\n typeof window !== 'undefined' &&\n ((window as { server?: { pretender: unknown } }).server?.pretender ||\n window.fetch.toString().replace(/\\s+/g, '') !== 'function fetch() { [native code] }'.replace(/\\s+/g, ''))\n );\n}\n\nconst MUTATION_OPS = new Set(['updateRecord', 'createRecord', 'deleteRecord']);\nconst ERROR_STATUS_CODE_FOR = new Map([\n [400, 'Bad Request'],\n [401, 'Unauthorized'],\n [402, 'Payment Required'],\n [403, 'Forbidden'],\n [404, 'Not Found'],\n [405, 'Method Not Allowed'],\n [406, 'Not Acceptable'],\n [407, 'Proxy Authentication Required'],\n [408, 'Request Timeout'],\n [409, 'Conflict'],\n [410, 'Gone'],\n [411, 'Length Required'],\n [412, 'Precondition Failed'],\n [413, 'Payload Too Large'],\n [414, 'URI Too Long'],\n [415, 'Unsupported Media Type'],\n [416, 'Range Not Satisfiable'],\n [417, 'Expectation Failed'],\n [419, 'Page Expired'],\n [420, 'Enhance Your Calm'],\n [421, 'Misdirected Request'],\n [422, 'Unprocessable Entity'],\n [423, 'Locked'],\n [424, 'Failed Dependency'],\n [425, 'Too Early'],\n [426, 'Upgrade Required'],\n [428, 'Precondition Required'],\n [429, 'Too Many Requests'],\n [430, 'Request Header Fields Too Large'],\n [431, 'Request Header Fields Too Large'],\n [450, 'Blocked By Windows Parental Controls'],\n [451, 'Unavailable For Legal Reasons'],\n [500, 'Internal Server Error'],\n [501, 'Not Implemented'],\n [502, 'Bad Gateway'],\n [503, 'Service Unavailable'],\n [504, 'Gateway Timeout'],\n [505, 'HTTP Version Not Supported'],\n [506, 'Variant Also Negotiates'],\n [507, 'Insufficient Storage'],\n [508, 'Loop Detected'],\n [509, 'Bandwidth Limit Exceeded'],\n [510, 'Not Extended'],\n [511, 'Network Authentication Required'],\n]);\n\n/**\n * A basic handler which converts a request into a\n * `fetch` call presuming the response to be `json`.\n *\n * ```ts\n * import Fetch from '@ember-data/request/fetch';\n *\n * manager.use([Fetch]);\n * ```\n *\n * @class Fetch\n * @public\n */\nconst Fetch = {\n async request<T>(context: Context): Promise<T> {\n let response: Response;\n\n try {\n assert(\n 'The Fetch handler expects the request to have a URL, none was provided.',\n context.request.url && typeof context.request.url === 'string'\n );\n response = await _fetch(context.request.url, context.request);\n } catch (e) {\n if (e instanceof DOMException && e.name === 'AbortError') {\n (e as HttpErrorProps).statusText = 'Aborted';\n (e as HttpErrorProps).status = 20;\n (e as HttpErrorProps).isRequestError = true;\n } else {\n (e as HttpErrorProps).statusText = 'Unknown Network Error';\n (e as HttpErrorProps).status = 0;\n (e as HttpErrorProps).isRequestError = true;\n }\n throw e;\n }\n\n const isError = !response.ok || response.status >= 400;\n const op = context.request.op;\n const isMutationOp = Boolean(op && MUTATION_OPS.has(op));\n\n if (!isError && !isMutationOp && response.status !== 204 && !response.headers.has('date')) {\n if (IS_MAYBE_MIRAGE()) {\n response.headers.set('date', new Date().toUTCString());\n } else {\n const headers = new Headers(response.headers);\n headers.set('date', new Date().toUTCString());\n response = cloneResponse(response, {\n headers,\n });\n }\n }\n\n context.setResponse(response);\n\n if (response.status === 204) {\n return null as T;\n }\n\n let text = '';\n // if we are in a mirage context, we cannot support streaming\n if (IS_MAYBE_MIRAGE()) {\n text = await response.text();\n } else {\n const reader = response.body!.getReader();\n const decoder = new TextDecoder();\n let isStreaming = context.hasRequestedStream;\n let stream: TransformStream | null = isStreaming ? new TransformStream() : null;\n let writer = stream?.writable.getWriter();\n\n if (isStreaming) {\n // Listen for the abort event on the AbortSignal\n context.request.signal?.addEventListener('abort', () => {\n if (!isStreaming) {\n return;\n }\n void stream!.writable.abort('Request Aborted');\n void stream!.readable.cancel('Request Aborted');\n });\n context.setStream(stream!.readable);\n }\n\n while (true) {\n // we manually read the stream instead of using `response.json()`\n // or `response.text()` because if we need to stream the body\n // we need to be able to pass the stream along efficiently.\n const { done, value } = await reader.read();\n if (done) {\n if (isStreaming) {\n isStreaming = false;\n await writer!.ready;\n await writer!.close();\n }\n break;\n }\n text += decoder.decode(value, { stream: true });\n\n // if we are streaming, we want to pass the stream along\n if (isStreaming) {\n await writer!.ready;\n await writer!.write(value);\n } else if (context.hasRequestedStream) {\n const encode = new TextEncoder();\n isStreaming = true;\n stream = new TransformStream();\n // Listen for the abort event on the AbortSignal\n // eslint-disable-next-line @typescript-eslint/no-loop-func\n context.request.signal?.addEventListener('abort', () => {\n if (!isStreaming) {\n return;\n }\n void stream!.writable.abort('Request Aborted');\n void stream!.readable.cancel('Request Aborted');\n });\n context.setStream(stream.readable);\n writer = stream.writable.getWriter();\n await writer.ready;\n await writer.write(encode.encode(text));\n await writer.ready;\n await writer.write(value);\n }\n }\n\n if (isStreaming) {\n isStreaming = false;\n await writer!.ready;\n await writer!.close();\n }\n }\n // if we are an error, we will want to throw\n if (isError) {\n let errorPayload: object | undefined;\n try {\n errorPayload = JSON.parse(text) as object;\n } catch {\n // void;\n }\n // attempt errors discovery\n const errors = Array.isArray(errorPayload)\n ? errorPayload\n : isDict(errorPayload) && Array.isArray(errorPayload.errors)\n ? errorPayload.errors\n : null;\n\n const statusText = response.statusText || ERROR_STATUS_CODE_FOR.get(response.status) || 'Unknown Request Error';\n const msg = `[${response.status} ${statusText}] ${context.request.method ?? 'GET'} (${response.type}) - ${\n response.url\n }`;\n\n const error = (errors ? new AggregateError(errors, msg) : new Error(msg)) as Error & {\n content: object | undefined;\n } & HttpErrorProps;\n error.status = response.status;\n error.statusText = statusText;\n error.isRequestError = true;\n error.code = error.status;\n error.name = error.statusText.replaceAll(' ', '') + 'Error';\n error.content = errorPayload;\n throw error;\n } else {\n return JSON.parse(text) as T;\n }\n },\n};\n\nfunction isDict(v: unknown): v is Record<string, unknown> {\n return v !== null && typeof v === 'object';\n}\n\nexport { Fetch };\n","import { DEBUG, TESTING } from '@warp-drive/core/build-config/env';\n\nimport { waitFor } from '../../store/-private/new-core-tmp/reactivity/configure';\nimport { peekUniversalTransient, setUniversalTransient } from '../../types/-private';\nimport type { StableDocumentIdentifier } from '../../types/identifier';\nimport type { RequestInfo, StructuredErrorDocument } from '../../types/request';\nimport { assertValidRequest } from './debug';\nimport { upgradePromise } from './future';\nimport { clearRequestResult, getRequestResult, setPromiseResult } from './promise-cache';\nimport type { CacheHandler, Future, GenericCreateArgs, Handler, ManagedRequestPriority } from './types';\nimport { executeNextHandler, IS_CACHE_HANDLER } from './utils';\n\n/**\n * ## Import\n *\n * ```js\n * import { RequestManager } from '@warp-drive/core';\n * ```\n *\n * For complete usage guide see the [RequestManager Documentation](/guides/).\n *\n * ## How It Works\n *\n * ```ts\n * interface RequestManager {\n * request<T>(req: RequestInfo): Future<T>;\n * }\n * ```\n *\n * A RequestManager provides a request/response flow in which configured\n * handlers are successively given the opportunity to handle, modify, or\n * pass-along a request.\n *\n * <img src=\"/images/handlers-all-labeled.gif\" alt=\"RequestManager Flow Animation\" width=\"100%\" />\n *\n * For example:\n *\n * ::: code-group\n *\n * ```ts [Setup.ts]\n * import { RequestManager, Fetch } from '@warp-drive/core';\n * import { AutoCompress } from '@warp-drive/utilities/handlers';\n * import Auth from 'ember-simple-auth/handler';\n *\n * // ... create manager\n * const manager = new RequestManager()\n * .use([Auth, new AutoCompress(), Fetch]); // [!code focus]\n * ```\n *\n * ```ts [Usage.ts]\n * import Config from './config';\n *\n * const { apiUrl } = Config;\n *\n * // ... execute a request\n * const response = await manager.request({\n * url: `${apiUrl}/users`\n * });\n * ```\n *\n * :::\n *\n * ### Futures\n *\n * The return value of `manager.request` is a `Future`, which allows\n * access to limited information about the request while it is still\n * pending and fulfills with the final state when the request completes.\n *\n * A `Future` is cancellable via `abort`.\n *\n * Handlers may optionally expose a `ReadableStream` to the `Future` for\n * streaming data; however, when doing so the future should not resolve\n * until the response stream is fully read.\n *\n * ```ts\n * interface Future<T> extends Promise<StructuredDocument<T>> {\n * abort(): void;\n *\n * async getStream(): ReadableStream | null;\n * }\n * ```\n *\n * ### StructuredDocuments\n *\n * A Future resolves with a `StructuredDataDocument` or rejects with a `StructuredErrorDocument`.\n *\n * ```ts\n * interface StructuredDataDocument<T> {\n * request: ImmutableRequestInfo;\n * response: ImmutableResponseInfo;\n * content: T;\n * }\n * interface StructuredErrorDocument extends Error {\n * request: ImmutableRequestInfo;\n * response: ImmutableResponseInfo;\n * error: string | object;\n * }\n * type StructuredDocument<T> = StructuredDataDocument<T> | StructuredErrorDocument;\n * ```\n *\n * @class RequestManager\n * @public\n */\nexport class RequestManager {\n #handlers: Handler[] = [];\n /** @internal */\n declare _hasCacheHandler: boolean;\n /**\n * A map of pending requests from request.id to their\n * associated CacheHandler promise.\n *\n * This queue is managed by the CacheHandler\n *\n * @internal\n */\n declare _pending: Map<number, Promise<unknown>>;\n /** @internal */\n declare _deduped: Map<StableDocumentIdentifier, { priority: ManagedRequestPriority; promise: Promise<unknown> }>;\n\n constructor(options?: GenericCreateArgs) {\n Object.assign(this, options);\n this._pending = new Map();\n this._deduped = new Map();\n }\n\n /**\n * Register a handler to use for primary cache intercept.\n *\n * Only one such handler may exist. If using the same\n * RequestManager as the Store instance the Store\n * registers itself as a Cache handler.\n *\n * @public\n */\n useCache(cacheHandler: CacheHandler & { [IS_CACHE_HANDLER]?: true }): this {\n if (DEBUG) {\n if (this._hasCacheHandler) {\n throw new Error(`\\`RequestManager.useCache(<handler>)\\` May only be invoked once.`);\n }\n if (Object.isFrozen(this.#handlers)) {\n throw new Error(\n `\\`RequestManager.useCache(<handler>)\\` May only be invoked prior to any request having been made.`\n );\n }\n this._hasCacheHandler = true;\n }\n cacheHandler[IS_CACHE_HANDLER] = true;\n this.#handlers.unshift(cacheHandler as Handler);\n return this;\n }\n\n /**\n * Register handler(s) to use when a request is issued.\n *\n * Handlers will be invoked in the order they are registered.\n * Each Handler is given the opportunity to handle the request,\n * curry the request, or pass along a modified request.\n *\n * @public\n * @param {Handler[]} newHandlers\n * @return {ThisType}\n */\n use(newHandlers: Handler[]): this {\n const handlers = this.#handlers;\n if (DEBUG) {\n if (Object.isFrozen(handlers)) {\n throw new Error(`Cannot add a Handler to a RequestManager after a request has been made`);\n }\n if (!Array.isArray(newHandlers)) {\n throw new Error(\n `\\`RequestManager.use(<Handler[]>)\\` expects an array of handlers, but was called with \\`${typeof newHandlers}\\``\n );\n }\n newHandlers.forEach((handler, index) => {\n if (\n !handler ||\n (typeof handler !== 'function' && typeof handler !== 'object') ||\n typeof handler.request !== 'function'\n ) {\n throw new Error(\n `\\`RequestManager.use(<Handler[]>)\\` expected to receive an array of handler objects with request methods, by the handler at index ${index} does not conform.`\n );\n }\n });\n }\n handlers.push(...newHandlers);\n return this;\n }\n\n /**\n * Issue a Request.\n *\n * Returns a Future that fulfills with a StructuredDocument\n *\n * @public\n * @param {RequestInfo} request\n * @return {Future}\n */\n request<RT, T = unknown>(request: RequestInfo<RT, T>): Future<RT> {\n const handlers = this.#handlers;\n if (DEBUG) {\n if (!Object.isFrozen(handlers)) {\n Object.freeze(handlers);\n }\n assertValidRequest(request, true);\n }\n\n const controller = request.controller || new AbortController();\n if (request.controller) {\n delete request.controller;\n }\n\n const requestId = peekUniversalTransient<number>('REQ_ID') ?? 0;\n setUniversalTransient('REQ_ID', requestId + 1);\n\n const context = {\n controller,\n response: null,\n stream: null,\n hasRequestedStream: false,\n id: requestId,\n identifier: null,\n };\n const promise = executeNextHandler<RT>(handlers, request, 0, context);\n\n // the cache handler will set the result of the request synchronously\n // if it is able to fulfill the request from the cache\n const cacheResult = getRequestResult(requestId);\n\n if (TESTING) {\n if (!request.disableTestWaiter) {\n const newPromise = waitFor(promise);\n const finalPromise = upgradePromise(\n newPromise.then(\n (result) => {\n setPromiseResult(finalPromise, { isError: false, result });\n clearRequestResult(requestId);\n return result;\n },\n (error: StructuredErrorDocument) => {\n setPromiseResult(finalPromise, { isError: true, result: error });\n clearRequestResult(requestId);\n throw error;\n }\n ),\n promise\n );\n\n if (cacheResult) {\n setPromiseResult(finalPromise, cacheResult);\n }\n\n return finalPromise;\n }\n }\n\n // const promise1 = store.request(myRequest);\n // const promise2 = store.request(myRequest);\n // promise1 === promise2; // false\n // either we need to make promise1 === promise2, or we need to make sure that\n // we need to have a way to key from request to result\n // such that we can lookup the result here and return it if it exists\n const finalPromise = upgradePromise(\n promise.then(\n (result) => {\n setPromiseResult(finalPromise, { isError: false, result });\n clearRequestResult(requestId);\n return result;\n },\n (error: StructuredErrorDocument) => {\n setPromiseResult(finalPromise, { isError: true, result: error });\n clearRequestResult(requestId);\n throw error;\n }\n ),\n promise\n );\n\n if (cacheResult) {\n setPromiseResult(finalPromise, cacheResult);\n }\n\n return finalPromise;\n }\n\n /**\n * This method exists so that the RequestManager can be created\n * can be created by container/factory systems that expect to\n * call a static `create` method to instantiate the class.\n *\n * Using `new RequestManager()` directly is preferred.\n *\n * @private\n */\n static create(options?: GenericCreateArgs) {\n return new this(options);\n }\n}\n","/**\n * @module\n * @mergeModuleWith <project>\n */\n\nimport type { ReactiveDocument } from './reactive/-private/document.ts';\nimport { getRuntimeConfig, setLogging } from './types/runtime.ts';\n\nexport { Fetch } from './request/-private/fetch.ts';\nexport { RequestManager } from './request/-private/manager.ts';\n\n// @ts-expect-error adding to globalThis\nglobalThis.setWarpDriveLogging = setLogging;\n\n// @ts-expect-error adding to globalThis\nglobalThis.getWarpDriveRuntimeConfig = getRuntimeConfig;\n\nexport {\n Store,\n type StoreRequestContext,\n CacheHandler,\n type CachePolicy,\n type StoreRequestInput,\n recordIdentifierFor,\n storeFor,\n} from './store/-private.ts';\n\n/**\n * @deprecated use `ReactiveDocument` instead\n */\nexport type Document<T> = ReactiveDocument<T>;\n\nexport type {\n DocumentCacheOperation,\n CacheOperation,\n NotificationType,\n} from './store/-private/managers/notification-manager.ts';\n\nexport {\n setIdentifierGenerationMethod,\n setIdentifierUpdateMethod,\n setIdentifierForgetMethod,\n setIdentifierResetMethod,\n setKeyInfoForResource,\n} from './store/-private/caches/identifier-cache.ts';\n"],"names":["_fetch","fetch","args","FastBoot","require","Error","cloneResponse","response","overrides","props","cloneResponseProperties","Response","body","Object","assign","IS_MAYBE_MIRAGE","macroCondition","getGlobalConfig","WarpDrive","env","DEBUG","Boolean","window","server","pretender","toString","replace","MUTATION_OPS","Set","ERROR_STATUS_CODE_FOR","Map","Fetch","request","context","test","url","e","DOMException","name","statusText","status","isRequestError","isError","ok","op","isMutationOp","has","headers","set","Date","toUTCString","Headers","setResponse","text","reader","getReader","decoder","TextDecoder","isStreaming","hasRequestedStream","stream","TransformStream","writer","writable","getWriter","signal","addEventListener","abort","readable","cancel","setStream","done","value","read","ready","close","decode","write","encode","TextEncoder","errorPayload","JSON","parse","errors","Array","isArray","isDict","get","msg","method","type","error","AggregateError","code","replaceAll","content","v","RequestManager","constructor","options","_pending","_deduped","useCache","cacheHandler","_hasCacheHandler","isFrozen","IS_CACHE_HANDLER","unshift","use","newHandlers","handlers","forEach","handler","index","push","freeze","assertValidRequest","controller","AbortController","requestId","peekUniversalTransient","setUniversalTransient","id","identifier","promise","executeNextHandler","cacheResult","getRequestResult","TESTING","disableTestWaiter","newPromise","waitFor","finalPromise","upgradePromise","then","result","setPromiseResult","clearRequestResult","create","globalThis","setWarpDriveLogging","setLogging","getWarpDriveRuntimeConfig","getRuntimeConfig"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../src/request/-private/fetch.ts","../src/request/-private/manager.ts","../src/index.ts"],"sourcesContent":["import { DEBUG } from '@warp-drive/core/build-config/env';\nimport { assert } from '@warp-drive/core/build-config/macros';\n\nimport { cloneResponseProperties, type Context } from './context';\nimport type { HttpErrorProps } from './utils';\n\ninterface FastbootRequest extends Request {\n protocol: string;\n host: string;\n}\nexport interface FastBoot {\n require(moduleName: string): unknown;\n isFastBoot: boolean;\n request: FastbootRequest;\n}\n\n// Lazily close over fetch to avoid breaking Mirage\nconst _fetch: typeof fetch =\n typeof fetch !== 'undefined'\n ? (...args) => fetch(...args)\n : typeof FastBoot !== 'undefined'\n ? (...args) => ((FastBoot as FastBoot).require('node-fetch') as typeof fetch)(...args)\n : ((() => {\n throw new Error('No Fetch Implementation Found');\n }) as typeof fetch);\n\n// clones a response in a way that should still\n// allow it to stream\nfunction cloneResponse(response: Response, overrides: Partial<Response>) {\n const props = cloneResponseProperties(response);\n return new Response(response.body, Object.assign(props, overrides));\n}\n\nlet IS_MAYBE_MIRAGE = () => false;\nif (DEBUG) {\n IS_MAYBE_MIRAGE = () =>\n Boolean(\n typeof window !== 'undefined' &&\n ((window as { server?: { pretender: unknown } }).server?.pretender ||\n window.fetch.toString().replace(/\\s+/g, '') !== 'function fetch() { [native code] }'.replace(/\\s+/g, ''))\n );\n}\n\nconst MUTATION_OPS = new Set(['updateRecord', 'createRecord', 'deleteRecord']);\nconst ERROR_STATUS_CODE_FOR = new Map([\n [400, 'Bad Request'],\n [401, 'Unauthorized'],\n [402, 'Payment Required'],\n [403, 'Forbidden'],\n [404, 'Not Found'],\n [405, 'Method Not Allowed'],\n [406, 'Not Acceptable'],\n [407, 'Proxy Authentication Required'],\n [408, 'Request Timeout'],\n [409, 'Conflict'],\n [410, 'Gone'],\n [411, 'Length Required'],\n [412, 'Precondition Failed'],\n [413, 'Payload Too Large'],\n [414, 'URI Too Long'],\n [415, 'Unsupported Media Type'],\n [416, 'Range Not Satisfiable'],\n [417, 'Expectation Failed'],\n [419, 'Page Expired'],\n [420, 'Enhance Your Calm'],\n [421, 'Misdirected Request'],\n [422, 'Unprocessable Entity'],\n [423, 'Locked'],\n [424, 'Failed Dependency'],\n [425, 'Too Early'],\n [426, 'Upgrade Required'],\n [428, 'Precondition Required'],\n [429, 'Too Many Requests'],\n [430, 'Request Header Fields Too Large'],\n [431, 'Request Header Fields Too Large'],\n [450, 'Blocked By Windows Parental Controls'],\n [451, 'Unavailable For Legal Reasons'],\n [500, 'Internal Server Error'],\n [501, 'Not Implemented'],\n [502, 'Bad Gateway'],\n [503, 'Service Unavailable'],\n [504, 'Gateway Timeout'],\n [505, 'HTTP Version Not Supported'],\n [506, 'Variant Also Negotiates'],\n [507, 'Insufficient Storage'],\n [508, 'Loop Detected'],\n [509, 'Bandwidth Limit Exceeded'],\n [510, 'Not Extended'],\n [511, 'Network Authentication Required'],\n]);\n\n/**\n * ```ts\n * import { Fetch } from '@warp-drive/core';\n * ```\n *\n * A basic Fetch Handler which converts a request into a\n * `fetch` call presuming the response to be `json`.\n *\n * ```ts\n * import { RequestManager, Fetch } from '@warp-drive/core';\n *\n * const manager = new RequestManager()\n * .use([Fetch]);\n * ```\n *\n * @public\n */\nconst Fetch = {\n async request<T>(context: Context): Promise<T> {\n let response: Response;\n\n try {\n assert(\n 'The Fetch handler expects the request to have a URL, none was provided.',\n context.request.url && typeof context.request.url === 'string'\n );\n response = await _fetch(context.request.url, context.request);\n } catch (e) {\n if (e instanceof DOMException && e.name === 'AbortError') {\n (e as HttpErrorProps).statusText = 'Aborted';\n (e as HttpErrorProps).status = 20;\n (e as HttpErrorProps).isRequestError = true;\n } else {\n (e as HttpErrorProps).statusText = 'Unknown Network Error';\n (e as HttpErrorProps).status = 0;\n (e as HttpErrorProps).isRequestError = true;\n }\n throw e;\n }\n\n const isError = !response.ok || response.status >= 400;\n const op = context.request.op;\n const isMutationOp = Boolean(op && MUTATION_OPS.has(op));\n\n if (!isError && !isMutationOp && response.status !== 204 && !response.headers.has('date')) {\n if (IS_MAYBE_MIRAGE()) {\n response.headers.set('date', new Date().toUTCString());\n } else {\n const headers = new Headers(response.headers);\n headers.set('date', new Date().toUTCString());\n response = cloneResponse(response, {\n headers,\n });\n }\n }\n\n context.setResponse(response);\n\n if (response.status === 204) {\n return null as T;\n }\n\n let text = '';\n // if we are in a mirage context, we cannot support streaming\n if (IS_MAYBE_MIRAGE()) {\n text = await response.text();\n } else {\n const reader = response.body!.getReader();\n const decoder = new TextDecoder();\n let isStreaming = context.hasRequestedStream;\n let stream: TransformStream | null = isStreaming ? new TransformStream() : null;\n let writer = stream?.writable.getWriter();\n\n if (isStreaming) {\n // Listen for the abort event on the AbortSignal\n context.request.signal?.addEventListener('abort', () => {\n if (!isStreaming) {\n return;\n }\n void stream!.writable.abort('Request Aborted');\n void stream!.readable.cancel('Request Aborted');\n });\n context.setStream(stream!.readable);\n }\n\n while (true) {\n // we manually read the stream instead of using `response.json()`\n // or `response.text()` because if we need to stream the body\n // we need to be able to pass the stream along efficiently.\n const { done, value } = await reader.read();\n if (done) {\n if (isStreaming) {\n isStreaming = false;\n await writer!.ready;\n await writer!.close();\n }\n break;\n }\n text += decoder.decode(value, { stream: true });\n\n // if we are streaming, we want to pass the stream along\n if (isStreaming) {\n await writer!.ready;\n await writer!.write(value);\n } else if (context.hasRequestedStream) {\n const encode = new TextEncoder();\n isStreaming = true;\n stream = new TransformStream();\n // Listen for the abort event on the AbortSignal\n // eslint-disable-next-line @typescript-eslint/no-loop-func\n context.request.signal?.addEventListener('abort', () => {\n if (!isStreaming) {\n return;\n }\n void stream!.writable.abort('Request Aborted');\n void stream!.readable.cancel('Request Aborted');\n });\n context.setStream(stream.readable);\n writer = stream.writable.getWriter();\n await writer.ready;\n await writer.write(encode.encode(text));\n await writer.ready;\n await writer.write(value);\n }\n }\n\n if (isStreaming) {\n isStreaming = false;\n await writer!.ready;\n await writer!.close();\n }\n }\n // if we are an error, we will want to throw\n if (isError) {\n let errorPayload: object | undefined;\n try {\n errorPayload = JSON.parse(text) as object;\n } catch {\n // void;\n }\n // attempt errors discovery\n const errors = Array.isArray(errorPayload)\n ? errorPayload\n : isDict(errorPayload) && Array.isArray(errorPayload.errors)\n ? errorPayload.errors\n : null;\n\n const statusText = response.statusText || ERROR_STATUS_CODE_FOR.get(response.status) || 'Unknown Request Error';\n const msg = `[${response.status} ${statusText}] ${context.request.method ?? 'GET'} (${response.type}) - ${\n response.url\n }`;\n\n const error = (errors ? new AggregateError(errors, msg) : new Error(msg)) as Error & {\n content: object | undefined;\n } & HttpErrorProps;\n error.status = response.status;\n error.statusText = statusText;\n error.isRequestError = true;\n error.code = error.status;\n error.name = error.statusText.replaceAll(' ', '') + 'Error';\n error.content = errorPayload;\n throw error;\n } else {\n return JSON.parse(text) as T;\n }\n },\n};\n\nfunction isDict(v: unknown): v is Record<string, unknown> {\n return v !== null && typeof v === 'object';\n}\n\nexport { Fetch };\n","import { DEBUG, TESTING } from '@warp-drive/core/build-config/env';\n\nimport { waitFor } from '../../store/-private/new-core-tmp/reactivity/configure';\nimport { peekUniversalTransient, setUniversalTransient } from '../../types/-private';\nimport type { StableDocumentIdentifier } from '../../types/identifier';\nimport type { RequestInfo, StructuredErrorDocument } from '../../types/request';\nimport { assertValidRequest } from './debug';\nimport { upgradePromise } from './future';\nimport { clearRequestResult, getRequestResult, setPromiseResult } from './promise-cache';\nimport type { CacheHandler, Future, GenericCreateArgs, Handler, ManagedRequestPriority } from './types';\nimport { executeNextHandler, IS_CACHE_HANDLER } from './utils';\n\n/**\n * ## Import\n *\n * ```js\n * import { RequestManager } from '@warp-drive/core';\n * ```\n *\n * For complete usage guide see the [RequestManager Documentation](/guides/).\n *\n * ## How It Works\n *\n * ```ts\n * interface RequestManager {\n * request<T>(req: RequestInfo): Future<T>;\n * }\n * ```\n *\n * A RequestManager provides a request/response flow in which configured\n * handlers are successively given the opportunity to handle, modify, or\n * pass-along a request.\n *\n * <img src=\"/images/handlers-all-labeled.gif\" alt=\"RequestManager Flow Animation\" width=\"100%\" />\n *\n * For example:\n *\n * ::: code-group\n *\n * ```ts [Setup.ts]\n * import { RequestManager, Fetch } from '@warp-drive/core';\n * import { AutoCompress } from '@warp-drive/utilities/handlers';\n * import Auth from 'ember-simple-auth/handler';\n *\n * // ... create manager\n * const manager = new RequestManager()\n * .use([Auth, new AutoCompress(), Fetch]); // [!code focus]\n * ```\n *\n * ```ts [Usage.ts]\n * import Config from './config';\n *\n * const { apiUrl } = Config;\n *\n * // ... execute a request\n * const response = await manager.request({\n * url: `${apiUrl}/users`\n * });\n * ```\n *\n * :::\n *\n * ### Futures\n *\n * The return value of `manager.request` is a `Future`, which allows\n * access to limited information about the request while it is still\n * pending and fulfills with the final state when the request completes.\n *\n * A `Future` is cancellable via `abort`.\n *\n * Handlers may optionally expose a `ReadableStream` to the `Future` for\n * streaming data; however, when doing so the future should not resolve\n * until the response stream is fully read.\n *\n * ```ts\n * interface Future<T> extends Promise<StructuredDocument<T>> {\n * abort(): void;\n *\n * async getStream(): ReadableStream | null;\n * }\n * ```\n *\n * ### StructuredDocuments\n *\n * A Future resolves with a `StructuredDataDocument` or rejects with a `StructuredErrorDocument`.\n *\n * ```ts\n * interface StructuredDataDocument<T> {\n * request: ImmutableRequestInfo;\n * response: ImmutableResponseInfo;\n * content: T;\n * }\n * interface StructuredErrorDocument extends Error {\n * request: ImmutableRequestInfo;\n * response: ImmutableResponseInfo;\n * error: string | object;\n * }\n * type StructuredDocument<T> = StructuredDataDocument<T> | StructuredErrorDocument;\n * ```\n *\n * @class RequestManager\n * @public\n */\nexport class RequestManager {\n #handlers: Handler[] = [];\n /** @internal */\n declare _hasCacheHandler: boolean;\n /**\n * A map of pending requests from request.id to their\n * associated CacheHandler promise.\n *\n * This queue is managed by the CacheHandler\n *\n * @internal\n */\n declare _pending: Map<number, Promise<unknown>>;\n /** @internal */\n declare _deduped: Map<StableDocumentIdentifier, { priority: ManagedRequestPriority; promise: Promise<unknown> }>;\n\n constructor(options?: GenericCreateArgs) {\n Object.assign(this, options);\n this._pending = new Map();\n this._deduped = new Map();\n }\n\n /**\n * Register a handler to use for primary cache intercept.\n *\n * Only one such handler may exist. If using the same\n * RequestManager as the Store instance the Store\n * registers itself as a Cache handler.\n *\n * @public\n */\n useCache(cacheHandler: CacheHandler & { [IS_CACHE_HANDLER]?: true }): this {\n if (DEBUG) {\n if (this._hasCacheHandler) {\n throw new Error(`\\`RequestManager.useCache(<handler>)\\` May only be invoked once.`);\n }\n if (Object.isFrozen(this.#handlers)) {\n throw new Error(\n `\\`RequestManager.useCache(<handler>)\\` May only be invoked prior to any request having been made.`\n );\n }\n this._hasCacheHandler = true;\n }\n cacheHandler[IS_CACHE_HANDLER] = true;\n this.#handlers.unshift(cacheHandler as Handler);\n return this;\n }\n\n /**\n * Register handler(s) to use when a request is issued.\n *\n * Handlers will be invoked in the order they are registered.\n * Each Handler is given the opportunity to handle the request,\n * curry the request, or pass along a modified request.\n *\n * @public\n * @param {Handler[]} newHandlers\n * @return {ThisType}\n */\n use(newHandlers: Handler[]): this {\n const handlers = this.#handlers;\n if (DEBUG) {\n if (Object.isFrozen(handlers)) {\n throw new Error(`Cannot add a Handler to a RequestManager after a request has been made`);\n }\n if (!Array.isArray(newHandlers)) {\n throw new Error(\n `\\`RequestManager.use(<Handler[]>)\\` expects an array of handlers, but was called with \\`${typeof newHandlers}\\``\n );\n }\n newHandlers.forEach((handler, index) => {\n if (\n !handler ||\n (typeof handler !== 'function' && typeof handler !== 'object') ||\n typeof handler.request !== 'function'\n ) {\n throw new Error(\n `\\`RequestManager.use(<Handler[]>)\\` expected to receive an array of handler objects with request methods, by the handler at index ${index} does not conform.`\n );\n }\n });\n }\n handlers.push(...newHandlers);\n return this;\n }\n\n /**\n * Issue a Request.\n *\n * Returns a Future that fulfills with a StructuredDocument\n *\n * @public\n * @param {RequestInfo} request\n * @return {Future}\n */\n request<RT, T = unknown>(request: RequestInfo<RT, T>): Future<RT> {\n const handlers = this.#handlers;\n if (DEBUG) {\n if (!Object.isFrozen(handlers)) {\n Object.freeze(handlers);\n }\n assertValidRequest(request, true);\n }\n\n const controller = request.controller || new AbortController();\n if (request.controller) {\n delete request.controller;\n }\n\n const requestId = peekUniversalTransient<number>('REQ_ID') ?? 0;\n setUniversalTransient('REQ_ID', requestId + 1);\n\n const context = {\n controller,\n response: null,\n stream: null,\n hasRequestedStream: false,\n id: requestId,\n identifier: null,\n };\n const promise = executeNextHandler<RT>(handlers, request, 0, context);\n\n // the cache handler will set the result of the request synchronously\n // if it is able to fulfill the request from the cache\n const cacheResult = getRequestResult(requestId);\n\n if (TESTING) {\n if (!request.disableTestWaiter) {\n const newPromise = waitFor(promise);\n const finalPromise = upgradePromise(\n newPromise.then(\n (result) => {\n setPromiseResult(finalPromise, { isError: false, result });\n clearRequestResult(requestId);\n return result;\n },\n (error: StructuredErrorDocument) => {\n setPromiseResult(finalPromise, { isError: true, result: error });\n clearRequestResult(requestId);\n throw error;\n }\n ),\n promise\n );\n\n if (cacheResult) {\n setPromiseResult(finalPromise, cacheResult);\n }\n\n return finalPromise;\n }\n }\n\n // const promise1 = store.request(myRequest);\n // const promise2 = store.request(myRequest);\n // promise1 === promise2; // false\n // either we need to make promise1 === promise2, or we need to make sure that\n // we need to have a way to key from request to result\n // such that we can lookup the result here and return it if it exists\n const finalPromise = upgradePromise(\n promise.then(\n (result) => {\n setPromiseResult(finalPromise, { isError: false, result });\n clearRequestResult(requestId);\n return result;\n },\n (error: StructuredErrorDocument) => {\n setPromiseResult(finalPromise, { isError: true, result: error });\n clearRequestResult(requestId);\n throw error;\n }\n ),\n promise\n );\n\n if (cacheResult) {\n setPromiseResult(finalPromise, cacheResult);\n }\n\n return finalPromise;\n }\n\n /**\n * This method exists so that the RequestManager can be created\n * can be created by container/factory systems that expect to\n * call a static `create` method to instantiate the class.\n *\n * Using `new RequestManager()` directly is preferred.\n *\n * @private\n */\n static create(options?: GenericCreateArgs) {\n return new this(options);\n }\n}\n","/**\n * @module\n * @mergeModuleWith <project>\n */\n\nimport type { ReactiveDocument } from './reactive/-private/document.ts';\nimport { getRuntimeConfig, setLogging } from './types/runtime.ts';\n\nexport { Fetch } from './request/-private/fetch.ts';\nexport { RequestManager } from './request/-private/manager.ts';\n\n// @ts-expect-error adding to globalThis\nglobalThis.setWarpDriveLogging = setLogging;\n\n// @ts-expect-error adding to globalThis\nglobalThis.getWarpDriveRuntimeConfig = getRuntimeConfig;\n\nexport {\n Store,\n type StoreRequestContext,\n CacheHandler,\n type CachePolicy,\n type StoreRequestInput,\n recordIdentifierFor,\n storeFor,\n} from './store/-private.ts';\n\n/**\n * @deprecated use `ReactiveDocument` instead\n */\nexport type Document<T> = ReactiveDocument<T>;\n\nexport type {\n DocumentCacheOperation,\n CacheOperation,\n NotificationType,\n} from './store/-private/managers/notification-manager.ts';\n\nexport {\n setIdentifierGenerationMethod,\n setIdentifierUpdateMethod,\n setIdentifierForgetMethod,\n setIdentifierResetMethod,\n setKeyInfoForResource,\n} from './store/-private/caches/identifier-cache.ts';\n"],"names":["_fetch","fetch","args","FastBoot","require","Error","cloneResponse","response","overrides","props","cloneResponseProperties","Response","body","Object","assign","IS_MAYBE_MIRAGE","macroCondition","getGlobalConfig","WarpDrive","env","DEBUG","Boolean","window","server","pretender","toString","replace","MUTATION_OPS","Set","ERROR_STATUS_CODE_FOR","Map","Fetch","request","context","test","url","e","DOMException","name","statusText","status","isRequestError","isError","ok","op","isMutationOp","has","headers","set","Date","toUTCString","Headers","setResponse","text","reader","getReader","decoder","TextDecoder","isStreaming","hasRequestedStream","stream","TransformStream","writer","writable","getWriter","signal","addEventListener","abort","readable","cancel","setStream","done","value","read","ready","close","decode","write","encode","TextEncoder","errorPayload","JSON","parse","errors","Array","isArray","isDict","get","msg","method","type","error","AggregateError","code","replaceAll","content","v","RequestManager","constructor","options","_pending","_deduped","useCache","cacheHandler","_hasCacheHandler","isFrozen","IS_CACHE_HANDLER","unshift","use","newHandlers","handlers","forEach","handler","index","push","freeze","assertValidRequest","controller","AbortController","requestId","peekUniversalTransient","setUniversalTransient","id","identifier","promise","executeNextHandler","cacheResult","getRequestResult","TESTING","disableTestWaiter","newPromise","waitFor","finalPromise","upgradePromise","then","result","setPromiseResult","clearRequestResult","create","globalThis","setWarpDriveLogging","setLogging","getWarpDriveRuntimeConfig","getRuntimeConfig"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { macroCondition, getGlobalConfig } from '@embroider/macros';
2
2
  const name = "@warp-drive/core";
3
- const version = "5.6.0-alpha.12";
3
+ const version = "5.6.0-alpha.13";
4
4
 
5
5
  // in testing mode, we utilize globals to ensure only one copy exists of
6
6
  // these maps, due to bugs in ember-auto-import
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@warp-drive/core",
3
- "version": "5.6.0-alpha.12",
3
+ "version": "5.6.0-alpha.13",
4
4
  "description": "Core package for WarpDrive | All the Universal Basics",
5
5
  "keywords": [
6
6
  "ember-addon"
@@ -37,13 +37,13 @@
37
37
  },
38
38
  "dependencies": {
39
39
  "@embroider/macros": "^1.16.12",
40
- "@warp-drive/build-config": "5.6.0-alpha.12"
40
+ "@warp-drive/build-config": "5.6.0-alpha.13"
41
41
  },
42
42
  "devDependencies": {
43
43
  "@babel/core": "^7.26.10",
44
44
  "@babel/plugin-transform-typescript": "^7.27.0",
45
45
  "@babel/preset-typescript": "^7.27.0",
46
- "@warp-drive/internal-config": "5.6.0-alpha.12",
46
+ "@warp-drive/internal-config": "5.6.0-alpha.13",
47
47
  "decorator-transforms": "^2.3.0",
48
48
  "ember-source": "~6.3.0",
49
49
  "expect-type": "^1.2.1",