@warp-drive-mirror/experiments 0.0.1-beta.2 → 0.0.1-beta.4

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/LICENSE.md CHANGED
@@ -1,9 +1,23 @@
1
- The MIT License (MIT)
1
+ MIT License
2
2
 
3
- Copyright (C) 2024 EmberData and WarpDrive contributors
3
+ Copyright (c) 2017-2025 Ember.js and contributors
4
+ Copyright (c) 2011-2017 Tilde, Inc. and contributors
5
+ Copyright (c) 2011 LivingSocial Inc.
4
6
 
5
- Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
7
+ Permission is hereby granted, free of charge, to any person obtaining a copy
8
+ of this software and associated documentation files (the "Software"), to deal
9
+ in the Software without restriction, including without limitation the rights
10
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11
+ copies of the Software, and to permit persons to whom the Software is
12
+ furnished to do so, subject to the following conditions:
6
13
 
7
- The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
14
+ The above copyright notice and this permission notice shall be included in all
15
+ copies or substantial portions of the Software.
8
16
 
9
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
17
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23
+ SOFTWARE.
package/README.md CHANGED
@@ -1,13 +1,13 @@
1
1
  <p align="center">
2
2
  <img
3
3
  class="project-logo"
4
- src="./NCC-1701-a-blue.svg#gh-light-mode-only"
4
+ src="./logos/NCC-1701-a-blue.svg#gh-light-mode-only"
5
5
  alt="WarpDrive"
6
6
  width="120px"
7
7
  title="WarpDrive" />
8
8
  <img
9
9
  class="project-logo"
10
- src="./NCC-1701-a.svg#gh-dark-mode-only"
10
+ src="./logos/NCC-1701-a.svg#gh-dark-mode-only"
11
11
  alt="WarpDrive"
12
12
  width="120px"
13
13
  title="WarpDrive" />
@@ -1,4 +1,4 @@
1
- import { D as DocumentStorage } from "./index-Cn3o840t";
1
+ import { D as DocumentStorage } from "./index-CGCX7hY2";
2
2
  import { SkipCache } from '@warp-drive-mirror/core-types/request';
3
3
  import { macroCondition, getGlobalConfig } from '@embroider/macros';
4
4
  const WorkerScope = globalThis.SharedWorkerGlobalScope;
@@ -120,7 +120,7 @@ function softCloneResponse(response) {
120
120
  if (!response) return null;
121
121
  const clone = {};
122
122
  if (response.headers) {
123
- clone.headers = Array.from(response.headers.entries());
123
+ clone.headers = Array.from(response.headers);
124
124
  }
125
125
  clone.ok = response.ok;
126
126
  clone.redirected = response.redirected;
@@ -1 +1 @@
1
- {"version":3,"file":"data-worker.js","sources":["../src/data-worker/worker.ts","../src/data-worker/utils.ts","../src/data-worker/cache-handler.ts"],"sourcesContent":["import type { Future, ResponseInfo, StructuredDataDocument } from '@ember-data-mirror/request';\nimport type Store from '@ember-data-mirror/store';\n\nimport { DocumentStorage } from '../document-storage';\nimport type { AbortEventData, RequestEventData, ThreadInitEventData, WorkerThreadEvent } from './types';\n\nconst WorkerScope = (globalThis as unknown as { SharedWorkerGlobalScope: FunctionConstructor }).SharedWorkerGlobalScope;\n\nexport class DataWorker {\n declare store: Store;\n declare threads: Map<string, MessagePort>;\n declare pending: Map<string, Map<number, Future<unknown>>>;\n declare isSharedWorker: boolean;\n declare options: { persisted: boolean; scope?: string };\n declare storage: DocumentStorage;\n\n constructor(UserStore: typeof Store, options?: { persisted: boolean; scope?: string }) {\n // disable if running on main thread\n if (typeof window !== 'undefined') {\n return;\n }\n this.store = new UserStore();\n this.threads = new Map();\n this.pending = new Map();\n this.options = Object.assign({ persisted: false, scope: '' }, options);\n this.isSharedWorker = WorkerScope && globalThis instanceof WorkerScope;\n this.initialize();\n }\n\n initialize() {\n // enable the CacheHandler to access the worker\n (this.store as unknown as { _worker: DataWorker })._worker = this;\n if (this.options.persisted) {\n // will be accessed by the worker's CacheHandler off of store\n this.storage = new DocumentStorage({ scope: this.options.scope });\n }\n if (this.isSharedWorker) {\n (globalThis as unknown as { onconnect: typeof globalThis.onmessage }).onconnect = (e) => {\n const port = e.ports[0];\n port.onmessage = (event: MessageEvent<ThreadInitEventData>) => {\n const { type } = event.data;\n\n switch (type) {\n case 'connect':\n this.setupThread(event.data.thread, port);\n break;\n }\n };\n port.start();\n };\n } else {\n globalThis.onmessage = (event: MessageEvent<ThreadInitEventData>) => {\n const { type } = event.data;\n\n switch (type) {\n case 'connect':\n this.setupThread(event.data.thread, event.ports[0]);\n break;\n }\n };\n }\n }\n\n setupThread(thread: string, port: MessagePort) {\n this.threads.set(thread, port);\n this.pending.set(thread, new Map());\n port.onmessage = (event: WorkerThreadEvent) => {\n if (event.type === 'close') {\n this.threads.delete(thread);\n return;\n }\n\n const { type } = event.data;\n switch (type) {\n case 'abort':\n this.abortRequest(event.data);\n break;\n case 'request':\n void this.request(prepareRequest(event.data));\n break;\n }\n };\n }\n\n abortRequest(event: AbortEventData) {\n const { thread, id } = event;\n const future = this.pending.get(thread)!.get(id);\n\n if (future) {\n future.abort();\n this.pending.get(thread)!.delete(id);\n }\n }\n\n async request(event: RequestEventData) {\n const { thread, id, data } = event;\n\n try {\n const future = this.store.request(data);\n this.pending.get(thread)!.set(id, future);\n\n const result = await future;\n\n this.threads.get(thread)?.postMessage({ type: 'success-response', id, thread, data: prepareResponse(result) });\n } catch (error) {\n if (isAbortError(error)) return;\n\n this.threads.get(thread)?.postMessage({ type: 'error-response', id, thread, data: error });\n } finally {\n this.pending.get(thread)!.delete(id);\n }\n }\n}\n\ntype Mutable<T> = { -readonly [P in keyof T]: T[P] };\n\nfunction softCloneResponse(response: Response | ResponseInfo | null) {\n if (!response) return null;\n\n const clone: Partial<Mutable<Response>> = {};\n\n if (response.headers) {\n clone.headers = Array.from(response.headers.entries()) as unknown as Headers;\n }\n\n clone.ok = response.ok;\n clone.redirected = response.redirected;\n clone.status = response.status;\n clone.statusText = response.statusText;\n clone.type = response.type;\n clone.url = response.url;\n\n return clone;\n}\n\nfunction isAbortError(error: unknown): error is Error {\n return error instanceof Error && error.name === 'AbortError';\n}\n\nfunction prepareResponse<T>(result: StructuredDataDocument<T>) {\n const newResponse = {\n response: softCloneResponse(result.response),\n content: result.content,\n };\n\n return newResponse;\n}\n\nfunction prepareRequest(event: RequestEventData) {\n if (event.data.headers) {\n event.data.headers = new Headers(event.data.headers);\n }\n\n return event;\n}\n","import type Store from '@ember-data-mirror/store';\nimport type { StableDocumentIdentifier } from '@warp-drive-mirror/core-types/identifier';\nimport type {\n ImmutableCreateRequestOptions,\n ImmutableDeleteRequestOptions,\n ImmutableRequestInfo,\n ImmutableUpdateRequestOptions,\n StructuredDataDocument,\n} from '@warp-drive-mirror/core-types/request';\nimport type { ApiError } from '@warp-drive-mirror/core-types/spec/error';\n\nexport const MUTATION_OPS = new Set(['createRecord', 'updateRecord', 'deleteRecord']);\n\n/**\n * In a Worker, any time we are asked to make a request, data needs to be returned.\n * background requests are ergo no different than foreground requests.\n * @internal\n */\nexport function calcShouldFetch(\n store: Store,\n request: ImmutableRequestInfo,\n hasCachedValue: boolean,\n identifier: StableDocumentIdentifier | null\n): boolean {\n const { cacheOptions } = request;\n return (\n (request.op && MUTATION_OPS.has(request.op)) ||\n cacheOptions?.reload ||\n cacheOptions?.backgroundReload ||\n !hasCachedValue ||\n (store.lifetimes && identifier\n ? store.lifetimes.isHardExpired(identifier, store) || store.lifetimes.isSoftExpired(identifier, store)\n : false)\n );\n}\n\nexport function isMutation(\n request: Partial<ImmutableRequestInfo>\n): request is ImmutableUpdateRequestOptions | ImmutableCreateRequestOptions | ImmutableDeleteRequestOptions {\n return Boolean(request.op && MUTATION_OPS.has(request.op));\n}\n\nexport function isCacheAffecting<T>(document: StructuredDataDocument<T>): boolean {\n if (!isMutation(document.request)) {\n return true;\n }\n // a mutation combined with a 204 has no cache impact when no known records were involved\n // a createRecord with a 201 with an empty response and no known records should similarly\n // have no cache impact\n\n if (document.request.op === 'createRecord' && document.response?.status === 201) {\n return document.content ? Object.keys(document.content).length > 0 : false;\n }\n\n return document.response?.status !== 204;\n}\n\nfunction isAggregateError(error: Error & { errors?: ApiError[] }): error is AggregateError & { errors: ApiError[] } {\n return error instanceof AggregateError || (error.name === 'AggregateError' && Array.isArray(error.errors));\n}\n\ntype RobustError = Error & { error: string | object; errors?: ApiError[]; content?: unknown };\n\n// TODO @runspired, consider if we should deep freeze errors (potentially only in debug) vs cloning them\nexport function cloneError(error: RobustError) {\n const isAggregate = isAggregateError(error);\n\n const cloned = (\n isAggregate ? new AggregateError(structuredClone(error.errors), error.message) : new Error(error.message)\n ) as RobustError;\n cloned.stack = error.stack!;\n cloned.error = error.error;\n\n // copy over enumerable properties\n Object.assign(cloned, error);\n\n return cloned;\n}\n","import type { CacheHandler as CacheHandlerType, Future, NextFn } from '@ember-data-mirror/request';\nimport type Store from '@ember-data-mirror/store';\nimport type { StoreRequestContext } from '@ember-data-mirror/store';\nimport { DEBUG } from '@warp-drive-mirror/build-config/env';\nimport { assert } from '@warp-drive-mirror/build-config/macros';\nimport type { ExistingRecordIdentifier, StableDocumentIdentifier } from '@warp-drive-mirror/core-types/identifier';\nimport type {\n StructuredDataDocument,\n StructuredDocument,\n StructuredErrorDocument,\n} from '@warp-drive-mirror/core-types/request';\nimport { SkipCache } from '@warp-drive-mirror/core-types/request';\nimport type {\n ResourceDataDocument,\n ResourceDocument,\n ResourceErrorDocument,\n} from '@warp-drive-mirror/core-types/spec/document';\nimport type { ApiError } from '@warp-drive-mirror/core-types/spec/error';\nimport type { ExistingResourceObject } from '@warp-drive-mirror/core-types/spec/json-api-raw';\n\nimport { calcShouldFetch, cloneError, isCacheAffecting, isMutation } from './utils';\nimport type { DataWorker } from './worker';\n\n/**\n * A simplified CacheHandler that hydrates ResourceDataDocuments from the cache\n * with their referenced resources.\n *\n * @typedoc\n */\nexport const CacheHandler: CacheHandlerType = {\n request<T>(context: StoreRequestContext, next: NextFn<T>): Promise<T | StructuredDataDocument<T>> | Future<T> | T {\n // if we have no cache or no cache-key skip cache handling\n if (!context.request.store || context.request.cacheOptions?.[SkipCache]) {\n return next(context.request);\n }\n\n const { store } = context.request;\n const identifier = store.identifierCache.getOrCreateDocumentIdentifier(context.request);\n const peeked = identifier ? store.cache.peekRequest(identifier) : null;\n\n if (identifier && !peeked) {\n // if we are using persisted cache, we should attempt to populate the in-memory cache now\n const worker = (store as unknown as { _worker: DataWorker })._worker;\n if (worker?.storage) {\n return worker.storage\n .getDocument(identifier)\n .then((document) => {\n if (document) {\n store.cache.put(document);\n }\n return completeRequest(identifier, store, context, next);\n })\n .catch((e) => {\n if (DEBUG) {\n // eslint-disable-next-line no-console\n console.log('Unable to retrieve document from persisted storage', e);\n }\n return completeRequest(identifier, store, context, next);\n });\n }\n }\n\n return completeRequest(identifier, store, context, next);\n },\n};\n\nfunction completeRequest<T>(\n identifier: StableDocumentIdentifier | null,\n store: Store,\n context: StoreRequestContext,\n next: NextFn<T>\n) {\n const peeked = identifier ? store.cache.peekRequest(identifier) : null;\n // In a Worker, any time we are asked to make a request, data needs to be returned.\n // background requests are ergo no different than foreground requests.\n if (calcShouldFetch(store, context.request, !!peeked, identifier)) {\n return fetchContentAndHydrate(next, context, identifier);\n }\n\n assert(`Expected a peeked request to be present`, peeked);\n context.setResponse(peeked.response);\n\n if ('error' in peeked) {\n throw peeked;\n }\n\n return maybeUpdateObjects<T>(store, peeked.content as ResourceDataDocument);\n}\n\nfunction maybeUpdateObjects<T>(store: Store, document: ResourceDataDocument | null): T {\n if (!document) {\n return document as T;\n }\n\n if (Array.isArray(document.data)) {\n const data = document.data.map((identifier) => {\n return store.cache.peek(identifier);\n });\n\n return Object.assign({}, document, { data }) as T;\n } else {\n const data = (document.data ? store.cache.peek(document.data) : null) as T;\n return Object.assign({}, document, { data }) as T;\n }\n}\n\nfunction maybeUpdatePersistedCache(\n store: Store,\n document: StructuredDocument<ResourceDocument<ExistingRecordIdentifier>> | null,\n resourceDocument?: ResourceDataDocument\n) {\n const worker = (store as unknown as { _worker: DataWorker })._worker;\n\n if (!worker?.storage) {\n return;\n }\n\n if (!document && resourceDocument) {\n // we have resources to update but not a full request to cache\n void worker.storage.putResources(resourceDocument, (resourceIdentifier) => {\n return store.cache.peek(resourceIdentifier) as ExistingResourceObject;\n });\n } else if (document) {\n void worker.storage.putDocument(document, (resourceIdentifier) => {\n return store.cache.peek(resourceIdentifier) as ExistingResourceObject;\n });\n }\n}\n\nfunction updateCacheForSuccess<T>(\n store: Store,\n request: StoreRequestContext['request'],\n document: StructuredDataDocument<T>\n) {\n let response: ResourceDataDocument | null = null;\n if (isMutation(request)) {\n const record = request.data?.record || request.records?.[0];\n if (record) {\n response = store.cache.didCommit(record, document) as ResourceDataDocument;\n\n // a mutation combined with a 204 has no cache impact when no known records were involved\n // a createRecord with a 201 with an empty response and no known records should similarly\n // have no cache impact\n } else if (isCacheAffecting(document)) {\n response = store.cache.put(document) as ResourceDataDocument;\n maybeUpdatePersistedCache(store, null, response);\n }\n } else {\n response = store.cache.put(document) as ResourceDataDocument;\n\n if (response.lid) {\n const identifier = store.identifierCache.getOrCreateDocumentIdentifier(request);\n const full = store.cache.peekRequest(identifier!);\n maybeUpdatePersistedCache(store, full);\n }\n }\n return maybeUpdateObjects(store, response);\n}\n\nfunction handleFetchSuccess<T>(\n store: Store,\n request: StoreRequestContext['request'],\n identifier: StableDocumentIdentifier | null,\n document: StructuredDataDocument<T>\n): T {\n let response: ResourceDataDocument;\n store._join(() => {\n response = updateCacheForSuccess<T>(store, request, document) as ResourceDataDocument;\n });\n\n if (store.lifetimes?.didRequest) {\n store.lifetimes.didRequest(request, document.response, identifier, store);\n }\n\n return response! as T;\n}\n\nfunction updateCacheForError<T>(\n store: Store,\n request: StoreRequestContext['request'],\n error: StructuredErrorDocument<T>\n) {\n if (isMutation(request)) {\n // TODO similar to didCommit we should spec this to be similar to cache.put for handling full response\n // currently we let the response remain undefiend.\n const errors =\n error &&\n error.content &&\n typeof error.content === 'object' &&\n 'errors' in error.content &&\n Array.isArray(error.content.errors)\n ? (error.content.errors as ApiError[])\n : undefined;\n\n const record = request.data?.record || request.records?.[0];\n\n store.cache.commitWasRejected(record, errors);\n } else {\n const identifier = store.identifierCache.getOrCreateDocumentIdentifier(request);\n if (identifier) {\n maybeUpdatePersistedCache(store, error as StructuredErrorDocument<ResourceErrorDocument>);\n }\n return store.cache.put(error) as ResourceErrorDocument;\n }\n}\n\nfunction handleFetchError<T>(\n store: Store,\n request: StoreRequestContext['request'],\n identifier: StableDocumentIdentifier | null,\n error: StructuredErrorDocument<T>\n): never {\n if (request.signal?.aborted) {\n throw error;\n }\n let response: ResourceErrorDocument | undefined;\n store._join(() => {\n response = updateCacheForError(store, request, error);\n });\n\n if (identifier && store.lifetimes?.didRequest) {\n store.lifetimes.didRequest(request, error.response, identifier, store);\n }\n\n if (isMutation(request)) {\n throw error;\n }\n\n const newError = cloneError(error);\n newError.content = response!;\n throw newError;\n}\n\nfunction fetchContentAndHydrate<T>(\n next: NextFn<T>,\n context: StoreRequestContext,\n identifier: StableDocumentIdentifier | null\n): Promise<T> {\n const { request } = context;\n const { store } = context.request;\n\n if (isMutation(request)) {\n // TODO should we handle multiple records in request.records by iteratively calling willCommit for each\n const record = request.data?.record || request.records?.[0];\n assert(`Expected to receive a list of records included in the ${request.op} request`, record);\n if (record) {\n store.cache.willCommit(record, context);\n }\n }\n\n if (store.lifetimes?.willRequest) {\n store.lifetimes.willRequest(request, identifier, store);\n }\n\n return next(request).then(\n (document) => handleFetchSuccess(store, request, identifier, document),\n (error: StructuredErrorDocument<T>) => handleFetchError(store, request, identifier, error)\n );\n}\n"],"names":["WorkerScope","globalThis","SharedWorkerGlobalScope","DataWorker","constructor","UserStore","options","window","store","threads","Map","pending","Object","assign","persisted","scope","isSharedWorker","initialize","_worker","storage","DocumentStorage","onconnect","e","port","ports","onmessage","event","type","data","setupThread","thread","start","set","delete","abortRequest","request","prepareRequest","id","future","get","abort","result","postMessage","prepareResponse","error","isAbortError","softCloneResponse","response","clone","headers","Array","from","entries","ok","redirected","status","statusText","url","Error","name","newResponse","content","Headers","MUTATION_OPS","Set","calcShouldFetch","hasCachedValue","identifier","cacheOptions","op","has","reload","backgroundReload","lifetimes","isHardExpired","isSoftExpired","isMutation","Boolean","isCacheAffecting","document","keys","length","isAggregateError","AggregateError","isArray","errors","cloneError","isAggregate","cloned","structuredClone","message","stack","CacheHandler","context","next","SkipCache","identifierCache","getOrCreateDocumentIdentifier","peeked","cache","peekRequest","worker","getDocument","then","put","completeRequest","catch","macroCondition","getGlobalConfig","WarpDrive","env","DEBUG","console","log","fetchContentAndHydrate","test","setResponse","maybeUpdateObjects","map","peek","maybeUpdatePersistedCache","resourceDocument","putResources","resourceIdentifier","putDocument","updateCacheForSuccess","record","records","didCommit","lid","full","handleFetchSuccess","_join","didRequest","updateCacheForError","undefined","commitWasRejected","handleFetchError","signal","aborted","newError","willCommit","willRequest"],"mappings":"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"}
1
+ {"version":3,"file":"data-worker.js","sources":["../src/data-worker/worker.ts","../src/data-worker/utils.ts","../src/data-worker/cache-handler.ts"],"sourcesContent":["import type { Future, ResponseInfo, StructuredDataDocument } from '@ember-data-mirror/request';\nimport type Store from '@ember-data-mirror/store';\n\nimport { DocumentStorage } from '../document-storage';\nimport type { AbortEventData, RequestEventData, ThreadInitEventData, WorkerThreadEvent } from './types';\n\nconst WorkerScope = (globalThis as unknown as { SharedWorkerGlobalScope: FunctionConstructor }).SharedWorkerGlobalScope;\n\nexport class DataWorker {\n declare store: Store;\n declare threads: Map<string, MessagePort>;\n declare pending: Map<string, Map<number, Future<unknown>>>;\n declare isSharedWorker: boolean;\n declare options: { persisted: boolean; scope?: string };\n declare storage: DocumentStorage;\n\n constructor(UserStore: typeof Store, options?: { persisted: boolean; scope?: string }) {\n // disable if running on main thread\n if (typeof window !== 'undefined') {\n return;\n }\n this.store = new UserStore();\n this.threads = new Map();\n this.pending = new Map();\n this.options = Object.assign({ persisted: false, scope: '' }, options);\n this.isSharedWorker = WorkerScope && globalThis instanceof WorkerScope;\n this.initialize();\n }\n\n initialize() {\n // enable the CacheHandler to access the worker\n (this.store as unknown as { _worker: DataWorker })._worker = this;\n if (this.options.persisted) {\n // will be accessed by the worker's CacheHandler off of store\n this.storage = new DocumentStorage({ scope: this.options.scope });\n }\n if (this.isSharedWorker) {\n (globalThis as unknown as { onconnect: typeof globalThis.onmessage }).onconnect = (e) => {\n const port = e.ports[0];\n port.onmessage = (event: MessageEvent<ThreadInitEventData>) => {\n const { type } = event.data;\n\n switch (type) {\n case 'connect':\n this.setupThread(event.data.thread, port);\n break;\n }\n };\n port.start();\n };\n } else {\n globalThis.onmessage = (event: MessageEvent<ThreadInitEventData>) => {\n const { type } = event.data;\n\n switch (type) {\n case 'connect':\n this.setupThread(event.data.thread, event.ports[0]);\n break;\n }\n };\n }\n }\n\n setupThread(thread: string, port: MessagePort) {\n this.threads.set(thread, port);\n this.pending.set(thread, new Map());\n port.onmessage = (event: WorkerThreadEvent) => {\n if (event.type === 'close') {\n this.threads.delete(thread);\n return;\n }\n\n const { type } = event.data;\n switch (type) {\n case 'abort':\n this.abortRequest(event.data);\n break;\n case 'request':\n void this.request(prepareRequest(event.data));\n break;\n }\n };\n }\n\n abortRequest(event: AbortEventData) {\n const { thread, id } = event;\n const future = this.pending.get(thread)!.get(id);\n\n if (future) {\n future.abort();\n this.pending.get(thread)!.delete(id);\n }\n }\n\n async request(event: RequestEventData) {\n const { thread, id, data } = event;\n\n try {\n const future = this.store.request(data);\n this.pending.get(thread)!.set(id, future);\n\n const result = await future;\n\n this.threads.get(thread)?.postMessage({ type: 'success-response', id, thread, data: prepareResponse(result) });\n } catch (error) {\n if (isAbortError(error)) return;\n\n this.threads.get(thread)?.postMessage({ type: 'error-response', id, thread, data: error });\n } finally {\n this.pending.get(thread)!.delete(id);\n }\n }\n}\n\ntype Mutable<T> = { -readonly [P in keyof T]: T[P] };\n\nfunction softCloneResponse(response: Response | ResponseInfo | null) {\n if (!response) return null;\n\n const clone: Partial<Mutable<Response>> = {};\n\n if (response.headers) {\n clone.headers = Array.from(response.headers as unknown as Iterable<[string, string][]>) as unknown as Headers;\n }\n\n clone.ok = response.ok;\n clone.redirected = response.redirected;\n clone.status = response.status;\n clone.statusText = response.statusText;\n clone.type = response.type;\n clone.url = response.url;\n\n return clone;\n}\n\nfunction isAbortError(error: unknown): error is Error {\n return error instanceof Error && error.name === 'AbortError';\n}\n\nfunction prepareResponse<T>(result: StructuredDataDocument<T>) {\n const newResponse = {\n response: softCloneResponse(result.response),\n content: result.content,\n };\n\n return newResponse;\n}\n\nfunction prepareRequest(event: RequestEventData) {\n if (event.data.headers) {\n event.data.headers = new Headers(event.data.headers);\n }\n\n return event;\n}\n","import type Store from '@ember-data-mirror/store';\nimport type { StableDocumentIdentifier } from '@warp-drive-mirror/core-types/identifier';\nimport type {\n ImmutableCreateRequestOptions,\n ImmutableDeleteRequestOptions,\n ImmutableRequestInfo,\n ImmutableUpdateRequestOptions,\n StructuredDataDocument,\n} from '@warp-drive-mirror/core-types/request';\nimport type { ApiError } from '@warp-drive-mirror/core-types/spec/error';\n\nexport const MUTATION_OPS = new Set(['createRecord', 'updateRecord', 'deleteRecord']);\n\n/**\n * In a Worker, any time we are asked to make a request, data needs to be returned.\n * background requests are ergo no different than foreground requests.\n * @internal\n */\nexport function calcShouldFetch(\n store: Store,\n request: ImmutableRequestInfo,\n hasCachedValue: boolean,\n identifier: StableDocumentIdentifier | null\n): boolean {\n const { cacheOptions } = request;\n return (\n (request.op && MUTATION_OPS.has(request.op)) ||\n cacheOptions?.reload ||\n cacheOptions?.backgroundReload ||\n !hasCachedValue ||\n (store.lifetimes && identifier\n ? store.lifetimes.isHardExpired(identifier, store) || store.lifetimes.isSoftExpired(identifier, store)\n : false)\n );\n}\n\nexport function isMutation(\n request: Partial<ImmutableRequestInfo>\n): request is ImmutableUpdateRequestOptions | ImmutableCreateRequestOptions | ImmutableDeleteRequestOptions {\n return Boolean(request.op && MUTATION_OPS.has(request.op));\n}\n\nexport function isCacheAffecting<T>(document: StructuredDataDocument<T>): boolean {\n if (!isMutation(document.request)) {\n return true;\n }\n // a mutation combined with a 204 has no cache impact when no known records were involved\n // a createRecord with a 201 with an empty response and no known records should similarly\n // have no cache impact\n\n if (document.request.op === 'createRecord' && document.response?.status === 201) {\n return document.content ? Object.keys(document.content).length > 0 : false;\n }\n\n return document.response?.status !== 204;\n}\n\nfunction isAggregateError(error: Error & { errors?: ApiError[] }): error is AggregateError & { errors: ApiError[] } {\n return error instanceof AggregateError || (error.name === 'AggregateError' && Array.isArray(error.errors));\n}\n\ntype RobustError = Error & { error: string | object; errors?: ApiError[]; content?: unknown };\n\n// TODO @runspired, consider if we should deep freeze errors (potentially only in debug) vs cloning them\nexport function cloneError(error: RobustError) {\n const isAggregate = isAggregateError(error);\n\n const cloned = (\n isAggregate ? new AggregateError(structuredClone(error.errors), error.message) : new Error(error.message)\n ) as RobustError;\n cloned.stack = error.stack!;\n cloned.error = error.error;\n\n // copy over enumerable properties\n Object.assign(cloned, error);\n\n return cloned;\n}\n","import type { CacheHandler as CacheHandlerType, Future, NextFn } from '@ember-data-mirror/request';\nimport type Store from '@ember-data-mirror/store';\nimport type { StoreRequestContext } from '@ember-data-mirror/store';\nimport { DEBUG } from '@warp-drive-mirror/build-config/env';\nimport { assert } from '@warp-drive-mirror/build-config/macros';\nimport type { ExistingRecordIdentifier, StableDocumentIdentifier } from '@warp-drive-mirror/core-types/identifier';\nimport type {\n StructuredDataDocument,\n StructuredDocument,\n StructuredErrorDocument,\n} from '@warp-drive-mirror/core-types/request';\nimport { SkipCache } from '@warp-drive-mirror/core-types/request';\nimport type {\n ResourceDataDocument,\n ResourceDocument,\n ResourceErrorDocument,\n} from '@warp-drive-mirror/core-types/spec/document';\nimport type { ApiError } from '@warp-drive-mirror/core-types/spec/error';\nimport type { ExistingResourceObject } from '@warp-drive-mirror/core-types/spec/json-api-raw';\n\nimport { calcShouldFetch, cloneError, isCacheAffecting, isMutation } from './utils';\nimport type { DataWorker } from './worker';\n\n/**\n * A simplified CacheHandler that hydrates ResourceDataDocuments from the cache\n * with their referenced resources.\n *\n * @typedoc\n */\nexport const CacheHandler: CacheHandlerType = {\n request<T>(context: StoreRequestContext, next: NextFn<T>): Promise<T | StructuredDataDocument<T>> | Future<T> | T {\n // if we have no cache or no cache-key skip cache handling\n if (!context.request.store || context.request.cacheOptions?.[SkipCache]) {\n return next(context.request);\n }\n\n const { store } = context.request;\n const identifier = store.identifierCache.getOrCreateDocumentIdentifier(context.request);\n const peeked = identifier ? store.cache.peekRequest(identifier) : null;\n\n if (identifier && !peeked) {\n // if we are using persisted cache, we should attempt to populate the in-memory cache now\n const worker = (store as unknown as { _worker: DataWorker })._worker;\n if (worker?.storage) {\n return worker.storage\n .getDocument(identifier)\n .then((document) => {\n if (document) {\n store.cache.put(document);\n }\n return completeRequest(identifier, store, context, next);\n })\n .catch((e) => {\n if (DEBUG) {\n // eslint-disable-next-line no-console\n console.log('Unable to retrieve document from persisted storage', e);\n }\n return completeRequest(identifier, store, context, next);\n });\n }\n }\n\n return completeRequest(identifier, store, context, next);\n },\n};\n\nfunction completeRequest<T>(\n identifier: StableDocumentIdentifier | null,\n store: Store,\n context: StoreRequestContext,\n next: NextFn<T>\n) {\n const peeked = identifier ? store.cache.peekRequest(identifier) : null;\n // In a Worker, any time we are asked to make a request, data needs to be returned.\n // background requests are ergo no different than foreground requests.\n if (calcShouldFetch(store, context.request, !!peeked, identifier)) {\n return fetchContentAndHydrate(next, context, identifier);\n }\n\n assert(`Expected a peeked request to be present`, peeked);\n context.setResponse(peeked.response);\n\n if ('error' in peeked) {\n throw peeked;\n }\n\n return maybeUpdateObjects<T>(store, peeked.content as ResourceDataDocument);\n}\n\nfunction maybeUpdateObjects<T>(store: Store, document: ResourceDataDocument | null): T {\n if (!document) {\n return document as T;\n }\n\n if (Array.isArray(document.data)) {\n const data = document.data.map((identifier) => {\n return store.cache.peek(identifier);\n });\n\n return Object.assign({}, document, { data }) as T;\n } else {\n const data = (document.data ? store.cache.peek(document.data) : null) as T;\n return Object.assign({}, document, { data }) as T;\n }\n}\n\nfunction maybeUpdatePersistedCache(\n store: Store,\n document: StructuredDocument<ResourceDocument<ExistingRecordIdentifier>> | null,\n resourceDocument?: ResourceDataDocument\n) {\n const worker = (store as unknown as { _worker: DataWorker })._worker;\n\n if (!worker?.storage) {\n return;\n }\n\n if (!document && resourceDocument) {\n // we have resources to update but not a full request to cache\n void worker.storage.putResources(resourceDocument, (resourceIdentifier) => {\n return store.cache.peek(resourceIdentifier) as ExistingResourceObject;\n });\n } else if (document) {\n void worker.storage.putDocument(document, (resourceIdentifier) => {\n return store.cache.peek(resourceIdentifier) as ExistingResourceObject;\n });\n }\n}\n\nfunction updateCacheForSuccess<T>(\n store: Store,\n request: StoreRequestContext['request'],\n document: StructuredDataDocument<T>\n) {\n let response: ResourceDataDocument | null = null;\n if (isMutation(request)) {\n const record = request.data?.record || request.records?.[0];\n if (record) {\n response = store.cache.didCommit(record, document) as ResourceDataDocument;\n\n // a mutation combined with a 204 has no cache impact when no known records were involved\n // a createRecord with a 201 with an empty response and no known records should similarly\n // have no cache impact\n } else if (isCacheAffecting(document)) {\n response = store.cache.put(document) as ResourceDataDocument;\n maybeUpdatePersistedCache(store, null, response);\n }\n } else {\n response = store.cache.put(document) as ResourceDataDocument;\n\n if (response.lid) {\n const identifier = store.identifierCache.getOrCreateDocumentIdentifier(request);\n const full = store.cache.peekRequest(identifier!);\n maybeUpdatePersistedCache(store, full);\n }\n }\n return maybeUpdateObjects(store, response);\n}\n\nfunction handleFetchSuccess<T>(\n store: Store,\n request: StoreRequestContext['request'],\n identifier: StableDocumentIdentifier | null,\n document: StructuredDataDocument<T>\n): T {\n let response: ResourceDataDocument;\n store._join(() => {\n response = updateCacheForSuccess<T>(store, request, document) as ResourceDataDocument;\n });\n\n if (store.lifetimes?.didRequest) {\n store.lifetimes.didRequest(request, document.response, identifier, store);\n }\n\n return response! as T;\n}\n\nfunction updateCacheForError<T>(\n store: Store,\n request: StoreRequestContext['request'],\n error: StructuredErrorDocument<T>\n) {\n if (isMutation(request)) {\n // TODO similar to didCommit we should spec this to be similar to cache.put for handling full response\n // currently we let the response remain undefiend.\n const errors =\n error &&\n error.content &&\n typeof error.content === 'object' &&\n 'errors' in error.content &&\n Array.isArray(error.content.errors)\n ? (error.content.errors as ApiError[])\n : undefined;\n\n const record = request.data?.record || request.records?.[0];\n\n store.cache.commitWasRejected(record, errors);\n } else {\n const identifier = store.identifierCache.getOrCreateDocumentIdentifier(request);\n if (identifier) {\n maybeUpdatePersistedCache(store, error as StructuredErrorDocument<ResourceErrorDocument>);\n }\n return store.cache.put(error) as ResourceErrorDocument;\n }\n}\n\nfunction handleFetchError<T>(\n store: Store,\n request: StoreRequestContext['request'],\n identifier: StableDocumentIdentifier | null,\n error: StructuredErrorDocument<T>\n): never {\n if (request.signal?.aborted) {\n throw error;\n }\n let response: ResourceErrorDocument | undefined;\n store._join(() => {\n response = updateCacheForError(store, request, error);\n });\n\n if (identifier && store.lifetimes?.didRequest) {\n store.lifetimes.didRequest(request, error.response, identifier, store);\n }\n\n if (isMutation(request)) {\n throw error;\n }\n\n const newError = cloneError(error);\n newError.content = response!;\n throw newError;\n}\n\nfunction fetchContentAndHydrate<T>(\n next: NextFn<T>,\n context: StoreRequestContext,\n identifier: StableDocumentIdentifier | null\n): Promise<T> {\n const { request } = context;\n const { store } = context.request;\n\n if (isMutation(request)) {\n // TODO should we handle multiple records in request.records by iteratively calling willCommit for each\n const record = request.data?.record || request.records?.[0];\n assert(`Expected to receive a list of records included in the ${request.op} request`, record);\n if (record) {\n store.cache.willCommit(record, context);\n }\n }\n\n if (store.lifetimes?.willRequest) {\n store.lifetimes.willRequest(request, identifier, store);\n }\n\n return next(request).then(\n (document) => handleFetchSuccess(store, request, identifier, document),\n (error: StructuredErrorDocument<T>) => handleFetchError(store, request, identifier, error)\n );\n}\n"],"names":["WorkerScope","globalThis","SharedWorkerGlobalScope","DataWorker","constructor","UserStore","options","window","store","threads","Map","pending","Object","assign","persisted","scope","isSharedWorker","initialize","_worker","storage","DocumentStorage","onconnect","e","port","ports","onmessage","event","type","data","setupThread","thread","start","set","delete","abortRequest","request","prepareRequest","id","future","get","abort","result","postMessage","prepareResponse","error","isAbortError","softCloneResponse","response","clone","headers","Array","from","ok","redirected","status","statusText","url","Error","name","newResponse","content","Headers","MUTATION_OPS","Set","calcShouldFetch","hasCachedValue","identifier","cacheOptions","op","has","reload","backgroundReload","lifetimes","isHardExpired","isSoftExpired","isMutation","Boolean","isCacheAffecting","document","keys","length","isAggregateError","AggregateError","isArray","errors","cloneError","isAggregate","cloned","structuredClone","message","stack","CacheHandler","context","next","SkipCache","identifierCache","getOrCreateDocumentIdentifier","peeked","cache","peekRequest","worker","getDocument","then","put","completeRequest","catch","macroCondition","getGlobalConfig","WarpDrive","env","DEBUG","console","log","fetchContentAndHydrate","test","setResponse","maybeUpdateObjects","map","peek","maybeUpdatePersistedCache","resourceDocument","putResources","resourceIdentifier","putDocument","updateCacheForSuccess","record","records","didCommit","lid","full","handleFetchSuccess","_join","didRequest","updateCacheForError","undefined","commitWasRejected","handleFetchError","signal","aborted","newError","willCommit","willRequest"],"mappings":"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"}
@@ -1 +1 @@
1
- export { D as DocumentStorage } from "./index-Cn3o840t";
1
+ export { D as DocumentStorage } from "./index-CGCX7hY2";
@@ -1 +1 @@
1
- {"version":3,"file":"image-fetch.js","sources":["../src/image-worker/fetch.ts"],"sourcesContent":["import { createDeferred } from '@ember-data-mirror/request';\nimport type { Deferred } from '@ember-data-mirror/request/-private/types';\nimport { TESTING } from '@warp-drive-mirror/build-config/env';\nimport { assert } from '@warp-drive-mirror/build-config/macros';\n\nimport type { MainThreadEvent, RequestEventData } from './types';\n\nexport interface FastBoot {\n require(moduleName: string): unknown;\n isFastBoot: boolean;\n request: Request;\n}\n\nconst isServerEnv = typeof FastBoot !== 'undefined';\n\nexport class ImageFetch {\n declare worker: Worker | SharedWorker;\n declare threadId: string;\n declare pending: Map<string, Deferred<string>>;\n declare channel: MessageChannel;\n declare cache: Map<string, string>;\n\n constructor(worker: Worker | SharedWorker | null) {\n this.threadId = isServerEnv ? '' : crypto.randomUUID();\n this.pending = new Map();\n this.cache = new Map();\n\n const isTesting = TESTING ? true : false;\n assert(`Expected a SharedWorker instance`, isTesting || isServerEnv || worker instanceof SharedWorker);\n this.worker = worker as SharedWorker;\n\n if (!isServerEnv) {\n const fn = (event: MainThreadEvent) => {\n const { type, url } = event.data;\n const deferred = this.cleanupRequest(url);\n if (!deferred) {\n return;\n }\n\n if (type === 'success-response') {\n deferred.resolve(url);\n return;\n }\n\n if (type === 'error-response') {\n deferred.reject(null);\n return;\n }\n };\n\n if (worker instanceof SharedWorker) {\n worker.port.postMessage({ type: 'connect', thread: this.threadId });\n worker.port.onmessage = fn;\n } else if (worker) {\n this.channel = new MessageChannel();\n worker.postMessage({ type: 'connect', thread: this.threadId }, [this.channel.port2]);\n\n this.channel.port1.onmessage = fn;\n }\n }\n }\n\n cleanupRequest(url: string) {\n const deferred = this.pending.get(url);\n this.pending.delete(url);\n\n return deferred;\n }\n\n _send(event: RequestEventData) {\n // eslint-disable-next-line @typescript-eslint/no-unused-expressions\n this.worker instanceof SharedWorker ? this.worker.port.postMessage(event) : this.channel.port1.postMessage(event);\n }\n\n load(url: string) {\n if (isServerEnv) {\n return Promise.resolve(url);\n }\n\n const objectUrl = this.cache.get(url);\n if (objectUrl) {\n return Promise.resolve(objectUrl);\n }\n\n const deferred = createDeferred<string>();\n this.pending.set(url, deferred);\n this._send({ type: 'load', thread: this.threadId, url });\n return deferred.promise;\n }\n}\n"],"names":["isServerEnv","FastBoot","ImageFetch","constructor","worker","threadId","crypto","randomUUID","pending","Map","cache","isTesting","macroCondition","getGlobalConfig","WarpDrive","env","TESTING","DEBUG","test","Error","SharedWorker","fn","event","type","url","data","deferred","cleanupRequest","resolve","reject","port","postMessage","thread","onmessage","channel","MessageChannel","port2","port1","get","delete","_send","load","Promise","objectUrl","createDeferred","set","promise"],"mappings":"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"}
1
+ {"version":3,"file":"image-fetch.js","sources":["../src/image-worker/fetch.ts"],"sourcesContent":["import { createDeferred } from '@ember-data-mirror/request';\nimport type { Deferred } from '@ember-data-mirror/request/-private/types';\nimport { TESTING } from '@warp-drive-mirror/build-config/env';\nimport { assert } from '@warp-drive-mirror/build-config/macros';\n\nimport type { MainThreadEvent, RequestEventData } from './types';\n\nexport interface FastBoot {\n require(moduleName: string): unknown;\n isFastBoot: boolean;\n request: Request;\n}\n\nconst isServerEnv = typeof FastBoot !== 'undefined';\n\nexport class ImageFetch {\n declare worker: Worker | SharedWorker;\n declare threadId: string;\n declare pending: Map<string, Deferred<string>>;\n declare channel: MessageChannel;\n declare cache: Map<string, string>;\n\n constructor(worker: Worker | SharedWorker | null) {\n this.threadId = isServerEnv ? '' : crypto.randomUUID();\n this.pending = new Map();\n this.cache = new Map();\n\n const isTesting = TESTING ? true : false;\n assert(`Expected a SharedWorker instance`, isTesting || isServerEnv || worker instanceof SharedWorker);\n this.worker = worker as SharedWorker;\n\n if (!isServerEnv) {\n const fn = (event: MainThreadEvent) => {\n const { type, url } = event.data;\n const deferred = this.cleanupRequest(url);\n if (!deferred) {\n return;\n }\n\n if (type === 'success-response') {\n deferred.resolve(url);\n return;\n }\n\n if (type === 'error-response') {\n deferred.reject(null);\n return;\n }\n };\n\n if (worker instanceof SharedWorker) {\n worker.port.postMessage({ type: 'connect', thread: this.threadId });\n worker.port.onmessage = fn;\n } else if (worker) {\n this.channel = new MessageChannel();\n worker.postMessage({ type: 'connect', thread: this.threadId }, [this.channel.port2]);\n\n this.channel.port1.onmessage = fn;\n }\n }\n }\n\n cleanupRequest(url: string) {\n const deferred = this.pending.get(url);\n this.pending.delete(url);\n\n return deferred;\n }\n\n _send(event: RequestEventData) {\n // eslint-disable-next-line @typescript-eslint/no-unused-expressions\n this.worker instanceof SharedWorker ? this.worker.port.postMessage(event) : this.channel.port1.postMessage(event);\n }\n\n load(url: string) {\n if (isServerEnv) {\n return Promise.resolve(url);\n }\n\n const objectUrl = this.cache.get(url);\n if (objectUrl) {\n return Promise.resolve(objectUrl);\n }\n\n const deferred = createDeferred<string>();\n this.pending.set(url, deferred);\n this._send({ type: 'load', thread: this.threadId, url });\n return deferred.promise;\n }\n}\n"],"names":["isServerEnv","FastBoot","ImageFetch","constructor","worker","threadId","crypto","randomUUID","pending","Map","cache","isTesting","macroCondition","getGlobalConfig","WarpDrive","env","TESTING","DEBUG","test","Error","SharedWorker","fn","event","type","url","data","deferred","cleanupRequest","resolve","reject","port","postMessage","thread","onmessage","channel","MessageChannel","port2","port1","get","delete","_send","load","Promise","objectUrl","createDeferred","set","promise"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"image-worker.js","sources":["../src/image-worker/worker.ts"],"sourcesContent":["import type { RequestEventData, ThreadInitEventData, WorkerThreadEvent } from './types';\n\nconst WorkerScope = (globalThis as unknown as { SharedWorkerGlobalScope: FunctionConstructor }).SharedWorkerGlobalScope;\n\nasync function loadImage(url: string): Promise<string> {\n const response = await fetch(url);\n const fileBlob = await response.blob();\n return URL.createObjectURL(fileBlob);\n}\n\nexport class ImageWorker {\n declare threads: Map<string, MessagePort>;\n declare pendingImages: Map<string, Promise<string>>;\n declare options: { persisted: boolean };\n declare isSharedWorker: boolean;\n declare cache: Map<string, string>;\n\n constructor(options?: { persisted: boolean }) {\n // disable if running on main thread\n if (typeof window !== 'undefined') {\n return;\n }\n this.threads = new Map();\n this.pendingImages = new Map();\n this.cache = new Map();\n this.options = options || { persisted: false };\n this.isSharedWorker = WorkerScope && globalThis instanceof WorkerScope;\n this.initialize();\n }\n\n fetch(url: string): Promise<string> {\n const objectUrl = this.cache.get(url);\n\n if (objectUrl) {\n return Promise.resolve(objectUrl);\n }\n\n const pending = this.pendingImages.get(url);\n if (pending) {\n return pending;\n }\n\n const promise = loadImage(url);\n this.pendingImages.set(url, promise);\n return promise.finally(() => {\n this.pendingImages.delete(url);\n });\n }\n\n initialize() {\n if (this.isSharedWorker) {\n (globalThis as unknown as { onconnect: typeof globalThis.onmessage }).onconnect = (e) => {\n const port = e.ports[0];\n port.onmessage = (event: MessageEvent<ThreadInitEventData>) => {\n const { type } = event.data;\n\n switch (type) {\n case 'connect':\n this.setupThread(event.data.thread, port);\n break;\n }\n };\n port.start();\n };\n } else {\n globalThis.onmessage = (event: MessageEvent<ThreadInitEventData>) => {\n const { type } = event.data;\n\n switch (type) {\n case 'connect':\n this.setupThread(event.data.thread, event.ports[0]);\n break;\n }\n };\n }\n }\n\n setupThread(thread: string, port: MessagePort) {\n this.threads.set(thread, port);\n port.onmessage = (event: WorkerThreadEvent) => {\n if (event.type === 'close') {\n this.threads.delete(thread);\n return;\n }\n\n const { type } = event.data;\n switch (type) {\n case 'load':\n void this.request(event.data);\n break;\n }\n };\n }\n\n async request(event: RequestEventData) {\n const { thread, url } = event;\n\n const objectUrl = await this.fetch(url);\n const port = this.threads.get(thread)!;\n port.postMessage({ type: 'success-response', thread, url, objectUrl });\n }\n}\n"],"names":["WorkerScope","globalThis","SharedWorkerGlobalScope","loadImage","url","response","fetch","fileBlob","blob","URL","createObjectURL","ImageWorker","constructor","options","window","threads","Map","pendingImages","cache","persisted","isSharedWorker","initialize","objectUrl","get","Promise","resolve","pending","promise","set","finally","delete","onconnect","e","port","ports","onmessage","event","type","data","setupThread","thread","start","request","postMessage"],"mappings":"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"}
1
+ {"version":3,"file":"image-worker.js","sources":["../src/image-worker/worker.ts"],"sourcesContent":["import type { RequestEventData, ThreadInitEventData, WorkerThreadEvent } from './types';\n\nconst WorkerScope = (globalThis as unknown as { SharedWorkerGlobalScope: FunctionConstructor }).SharedWorkerGlobalScope;\n\nasync function loadImage(url: string): Promise<string> {\n const response = await fetch(url);\n const fileBlob = await response.blob();\n return URL.createObjectURL(fileBlob);\n}\n\nexport class ImageWorker {\n declare threads: Map<string, MessagePort>;\n declare pendingImages: Map<string, Promise<string>>;\n declare options: { persisted: boolean };\n declare isSharedWorker: boolean;\n declare cache: Map<string, string>;\n\n constructor(options?: { persisted: boolean }) {\n // disable if running on main thread\n if (typeof window !== 'undefined') {\n return;\n }\n this.threads = new Map();\n this.pendingImages = new Map();\n this.cache = new Map();\n this.options = options || { persisted: false };\n this.isSharedWorker = WorkerScope && globalThis instanceof WorkerScope;\n this.initialize();\n }\n\n fetch(url: string): Promise<string> {\n const objectUrl = this.cache.get(url);\n\n if (objectUrl) {\n return Promise.resolve(objectUrl);\n }\n\n const pending = this.pendingImages.get(url);\n if (pending) {\n return pending;\n }\n\n const promise = loadImage(url);\n this.pendingImages.set(url, promise);\n return promise.finally(() => {\n this.pendingImages.delete(url);\n });\n }\n\n initialize() {\n if (this.isSharedWorker) {\n (globalThis as unknown as { onconnect: typeof globalThis.onmessage }).onconnect = (e) => {\n const port = e.ports[0];\n port.onmessage = (event: MessageEvent<ThreadInitEventData>) => {\n const { type } = event.data;\n\n switch (type) {\n case 'connect':\n this.setupThread(event.data.thread, port);\n break;\n }\n };\n port.start();\n };\n } else {\n globalThis.onmessage = (event: MessageEvent<ThreadInitEventData>) => {\n const { type } = event.data;\n\n switch (type) {\n case 'connect':\n this.setupThread(event.data.thread, event.ports[0]);\n break;\n }\n };\n }\n }\n\n setupThread(thread: string, port: MessagePort) {\n this.threads.set(thread, port);\n port.onmessage = (event: WorkerThreadEvent) => {\n if (event.type === 'close') {\n this.threads.delete(thread);\n return;\n }\n\n const { type } = event.data;\n switch (type) {\n case 'load':\n void this.request(event.data);\n break;\n }\n };\n }\n\n async request(event: RequestEventData) {\n const { thread, url } = event;\n\n const objectUrl = await this.fetch(url);\n const port = this.threads.get(thread)!;\n port.postMessage({ type: 'success-response', thread, url, objectUrl });\n }\n}\n"],"names":["WorkerScope","globalThis","SharedWorkerGlobalScope","loadImage","url","response","fetch","fileBlob","blob","URL","createObjectURL","ImageWorker","constructor","options","window","threads","Map","pendingImages","cache","persisted","isSharedWorker","initialize","objectUrl","get","Promise","resolve","pending","promise","set","finally","delete","onconnect","e","port","ports","onmessage","event","type","data","setupThread","thread","start","request","postMessage"],"mappings":"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"}
@@ -244,7 +244,7 @@ function prepareRequest(request) {
244
244
  delete requestCopy.signal;
245
245
  }
246
246
  if (headers instanceof Headers) {
247
- requestCopy.headers = Array.from(headers.entries());
247
+ requestCopy.headers = Array.from(headers);
248
248
  }
249
249
  return requestCopy;
250
250
  }
@@ -252,7 +252,7 @@ function prepareResponse(response) {
252
252
  if (!response) return null;
253
253
  const clone = {};
254
254
  if (response.headers) {
255
- clone.headers = Array.from(response.headers.entries());
255
+ clone.headers = Array.from(response.headers);
256
256
  }
257
257
  clone.ok = response.ok;
258
258
  clone.redirected = response.redirected;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-CGCX7hY2.js","sources":["../src/document-storage/index.ts"],"sourcesContent":["import type { RequestInfo, ResponseInfo, StructuredDocument } from '@ember-data-mirror/request';\nimport type { StoreRequestContext } from '@ember-data-mirror/store';\nimport { assert } from '@warp-drive-mirror/build-config/macros';\nimport type { ExistingRecordIdentifier } from '@warp-drive-mirror/core-types/identifier';\nimport type { ResourceDataDocument, ResourceDocument } from '@warp-drive-mirror/core-types/spec/document';\nimport type { ExistingResourceObject } from '@warp-drive-mirror/core-types/spec/json-api-raw';\n\nexport const WARP_DRIVE_STORAGE_FILE_NAME = 'warp-drive_document-storage';\nexport const WARP_DRIVE_STORAGE_VERSION = 1;\n\nexport type DocumentStorageOptions = {\n /**\n * The scope of the storage. This is used to enable multiple distinct\n * storage areas within the same origin.\n *\n * One use case for this is to have a separate storage area for each\n * user credential. So for instance, in applications that allow a single\n * user to have multiple accounts, each account can have its own storage!\n */\n scope: string;\n /**\n * When set to true, if other instances of the storage are created with\n * the same scope, they will not share the same in-memory cache and BroadcastChannel.\n *\n * This is mostly useful for testing purposes to replicate the behavior of\n * multiple tabs or workers.\n */\n isolated: boolean;\n};\n/**\n * DocumentStorage is specifically designed around WarpDrive Cache and Request concepts.\n *\n * CacheFileDocument is a StructuredDocument (request response) whose `content` is\n * the ResourceDocument returned by inserting the request into a Store's Cache.\n */\ntype CacheFileDocument = StructuredDocument<ResourceDocument<ExistingRecordIdentifier>>;\n/**\n * A CacheDocument is a reconstructed request response that rehydrates ResourceDocument\n * with the associated resources based on their identifiers.\n */\ntype CacheDocument = StructuredDocument<ResourceDocument<ExistingResourceObject>>;\ntype CacheResourceEntry = [string, ExistingResourceObject];\ntype CacheFile = {\n documents: [string, CacheFileDocument][];\n resources: CacheResourceEntry[];\n};\ntype DocumentIdentifier = { lid: string };\n\ntype MemCache = {\n documents: Map<string, CacheFileDocument>;\n resources: Map<string, ExistingResourceObject>;\n};\n\nclass InternalDocumentStorage {\n declare readonly options: DocumentStorageOptions;\n declare _fileHandle: Promise<FileSystemFileHandle>;\n declare _channel: BroadcastChannel;\n declare _invalidated: boolean;\n declare _lastModified: number;\n declare _cache: MemCache | null;\n declare _filePromise: Promise<MemCache> | null;\n\n constructor(options: DocumentStorageOptions) {\n this.options = options;\n\n this._lastModified = 0;\n this._invalidated = true;\n this._fileHandle = this._open(options.scope);\n this._channel = Object.assign(new BroadcastChannel(options.scope), {\n onmessage: this._onMessage.bind(this),\n });\n }\n\n _onMessage(_event: MessageEvent) {\n this._invalidated = true;\n }\n\n async _open(scope: string) {\n const directoryHandle = await navigator.storage.getDirectory();\n const fileHandle = await directoryHandle.getFileHandle(scope, { create: true });\n return fileHandle;\n }\n\n async _read(): Promise<MemCache> {\n if (this._filePromise) {\n return this._filePromise;\n }\n\n if (this._invalidated) {\n const updateFile = async () => {\n const fileHandle = await this._fileHandle;\n const file = await fileHandle.getFile();\n\n const lastModified = file.lastModified;\n if (lastModified === this._lastModified && this._cache) {\n return this._cache;\n }\n\n const contents = await file.text();\n const cache = contents ? (JSON.parse(contents) as CacheFile) : ({ documents: [], resources: [] } as CacheFile);\n\n const documents = new Map(cache.documents);\n const resources = new Map(cache.resources);\n\n const cacheMap = { documents, resources };\n this._cache = cacheMap;\n this._invalidated = false;\n this._lastModified = lastModified;\n return cacheMap;\n };\n this._filePromise = updateFile();\n await this._filePromise;\n this._filePromise = null;\n }\n\n return this._cache!;\n }\n\n async _patch(\n documentKey: string,\n document: CacheFileDocument,\n updatedResources: Map<string, ExistingResourceObject>\n ) {\n const fileHandle = await this._fileHandle;\n // secure a lock before getting latest state\n const writable = await fileHandle.createWritable();\n\n const cache = await this._read();\n cache.documents.set(documentKey, document);\n updatedResources.forEach((resource, key) => {\n cache.resources.set(key, resource);\n });\n\n const documents = [...cache.documents.entries()];\n const resources = [...cache.resources.entries()];\n const cacheFile: CacheFile = {\n documents,\n resources,\n };\n\n await writable.write(JSON.stringify(cacheFile));\n await writable.close();\n this._channel.postMessage({ type: 'patch', key: documentKey, resources: [...updatedResources.keys()] });\n }\n\n async getDocument(key: DocumentIdentifier): Promise<CacheDocument | null> {\n const cache = await this._read();\n // clone the document to avoid leaking the internal cache\n const document = safeDocumentHydrate(cache.documents.get(key.lid));\n\n if (!document) {\n return null;\n }\n\n // expand the document with the resources\n if (document.content) {\n if (docHasData(document.content)) {\n let data: ExistingResourceObject | ExistingResourceObject[] | null = null;\n if (Array.isArray(document.content.data)) {\n data = document.content.data.map((resourceIdentifier) => {\n const resource = cache.resources.get(resourceIdentifier.lid);\n if (!resource) {\n throw new Error(`Resource not found for ${resourceIdentifier.lid}`);\n }\n\n // clone the resource to avoid leaking the internal cache\n return structuredClone(resource);\n });\n } else if (document.content.data) {\n const resource = cache.resources.get(document.content.data.lid);\n if (!resource) {\n throw new Error(`Resource not found for ${document.content.data.lid}`);\n }\n\n // clone the resource to avoid leaking the internal cache\n data = structuredClone(resource);\n }\n\n if (document.content.included) {\n const included = document.content.included.map((resourceIdentifier) => {\n const resource = cache.resources.get(resourceIdentifier.lid);\n if (!resource) {\n throw new Error(`Resource not found for ${resourceIdentifier.lid}`);\n }\n\n // clone the resource to avoid leaking the internal cache\n return structuredClone(resource);\n });\n document.content.included = included as ExistingRecordIdentifier[];\n }\n\n document.content.data = data as unknown as ResourceDataDocument<ExistingRecordIdentifier>['data'];\n }\n }\n\n return document as CacheDocument;\n }\n\n async putDocument(\n document: CacheFileDocument,\n resourceCollector: (resourceIdentifier: ExistingRecordIdentifier) => ExistingResourceObject\n ): Promise<void> {\n const resources = new Map<string, ExistingResourceObject>();\n\n if (!document.content) {\n throw new Error(`Document content is missing, only finalized documents can be stored`);\n }\n\n if (!document.content.lid) {\n throw new Error(`Document content is missing a lid, only documents with a cache-key can be stored`);\n }\n\n if (docHasData(document.content)) {\n this._getResources(document.content, resourceCollector, resources);\n }\n\n await this._patch(document.content.lid, safeDocumentSerialize(document), resources);\n }\n\n _getResources(\n document: ResourceDataDocument<ExistingRecordIdentifier>,\n resourceCollector: (resourceIdentifier: ExistingRecordIdentifier) => ExistingResourceObject,\n resources: Map<string, ExistingResourceObject> = new Map<string, ExistingResourceObject>()\n ) {\n if (Array.isArray(document.data)) {\n document.data.forEach((resourceIdentifier) => {\n const resource = resourceCollector(resourceIdentifier);\n resources.set(resourceIdentifier.lid, structuredClone(resource));\n });\n } else if (document.data) {\n const resource = resourceCollector(document.data);\n resources.set(document.data.lid, structuredClone(resource));\n }\n\n if (document.included) {\n document.included.forEach((resourceIdentifier) => {\n const resource = resourceCollector(resourceIdentifier);\n resources.set(resourceIdentifier.lid, structuredClone(resource));\n });\n }\n\n return resources;\n }\n\n async putResources(\n document: ResourceDataDocument<ExistingRecordIdentifier>,\n resourceCollector: (resourceIdentifier: ExistingRecordIdentifier) => ExistingResourceObject\n ) {\n const fileHandle = await this._fileHandle;\n // secure a lock before getting latest state\n const writable = await fileHandle.createWritable();\n\n const cache = await this._read();\n const updatedResources = this._getResources(document, resourceCollector);\n\n updatedResources.forEach((resource, key) => {\n cache.resources.set(key, resource);\n });\n\n const documents = [...cache.documents.entries()];\n const resources = [...cache.resources.entries()];\n const cacheFile: CacheFile = {\n documents,\n resources,\n };\n\n await writable.write(JSON.stringify(cacheFile));\n await writable.close();\n this._channel.postMessage({ type: 'patch', key: null, resources: [...updatedResources.keys()] });\n }\n\n async clear(reset?: boolean) {\n const fileHandle = await this._fileHandle;\n const writable = await fileHandle.createWritable();\n await writable.write('');\n await writable.close();\n\n this._invalidated = true;\n this._lastModified = 0;\n this._cache = null;\n this._filePromise = null;\n this._channel.postMessage({ type: 'clear' });\n\n if (!reset) {\n this._channel.close();\n this._channel = null as unknown as BroadcastChannel;\n\n if (!this.options.isolated) {\n Storages.delete(this.options.scope);\n }\n }\n }\n}\n\nfunction safeDocumentSerialize<T>(document: T): T {\n assert(`Expected to receive a document`, document && typeof document === 'object');\n const doc = document as unknown as {\n request?: StoreRequestContext['request'];\n response?: Response;\n content?: unknown;\n };\n const newDoc: { request?: unknown; response?: unknown; content?: unknown } = {};\n if ('request' in doc) {\n newDoc.request = prepareRequest(doc.request!);\n }\n if ('response' in doc) {\n newDoc.response = prepareResponse(doc.response!);\n }\n\n if ('content' in doc) {\n newDoc.content = structuredClone(doc.content);\n }\n\n return newDoc as T;\n}\n\nfunction prepareRequest(request: StoreRequestContext['request']): RequestInfo {\n const { signal, headers } = request;\n const requestCopy = Object.assign({}, request) as RequestInfo;\n\n delete requestCopy.store;\n\n if (signal instanceof AbortSignal) {\n delete requestCopy.signal;\n }\n\n if (headers instanceof Headers) {\n requestCopy.headers = Array.from(headers as unknown as Iterable<[string, string][]>) as unknown as Headers;\n }\n\n return requestCopy;\n}\n\ntype Mutable<T> = { -readonly [P in keyof T]: T[P] };\n\nfunction prepareResponse(response: Response | ResponseInfo | null) {\n if (!response) return null;\n\n const clone: Partial<Mutable<Response>> = {};\n\n if (response.headers) {\n clone.headers = Array.from(response.headers as unknown as Iterable<[string, string][]>) as unknown as Headers;\n }\n\n clone.ok = response.ok;\n clone.redirected = response.redirected;\n clone.status = response.status;\n clone.statusText = response.statusText;\n clone.type = response.type;\n clone.url = response.url;\n\n return clone;\n}\n\nfunction safeDocumentHydrate<T>(document: T): T {\n assert(`Expected to receive a document`, document && typeof document === 'object');\n const doc = document as unknown as {\n request?: Request | StoreRequestContext['request'];\n response?: Response;\n content?: unknown;\n };\n const newDoc: { request?: StoreRequestContext['request'] | Request; response?: Response; content?: unknown } = {};\n\n if ('request' in doc) {\n const headers = new Headers(doc.request!.headers);\n const req = Object.assign({}, doc.request, { headers });\n newDoc.request = new Request(doc.request!.url ?? '', req);\n }\n\n if ('response' in doc) {\n const headers = new Headers(doc.response!.headers);\n const resp = Object.assign({}, doc.response, { headers });\n newDoc.response = new Response(null, resp);\n }\n\n if ('content' in doc) {\n newDoc.content = structuredClone(doc.content);\n }\n\n return newDoc as T;\n}\n\nfunction docHasData<T>(doc: ResourceDocument<T>): doc is ResourceDataDocument<T> {\n return 'data' in doc;\n}\n\nconst Storages = new Map<string, WeakRef<InternalDocumentStorage>>();\n\n/**\n * DocumentStorage is a wrapper around the StorageManager API that provides\n * a simple interface for reading and updating documents and requests.\n *\n * Some goals for this experiment:\n *\n * - optimize for storing requests/documents\n * - optimize for storing resources\n * - optimize for looking up resources associated to a document\n * - optimize for notifying cross-tab when data is updated\n *\n * optional features:\n *\n * - support for offline mode\n * - ?? support for relationship based cache traversal\n * - a way to index records by type + another field (e.g updatedAt/createAt/name)\n * such that simple queries can be done without having to scan all records\n */\nexport class DocumentStorage {\n declare readonly _storage: InternalDocumentStorage;\n\n constructor(options: Partial<DocumentStorageOptions> = {}) {\n options.isolated = options.isolated ?? false;\n options.scope = options.scope ?? 'default';\n\n const fileName = `${WARP_DRIVE_STORAGE_FILE_NAME}@version_${WARP_DRIVE_STORAGE_VERSION}:${options.scope}`;\n if (!options.isolated && Storages.has(fileName)) {\n const storage = Storages.get(fileName);\n if (storage) {\n this._storage = storage.deref()!;\n return;\n }\n }\n\n const storage = new InternalDocumentStorage({ scope: fileName, isolated: options.isolated });\n this._storage = storage;\n if (!options.isolated) {\n Storages.set(fileName, new WeakRef(storage));\n }\n }\n\n getDocument(key: DocumentIdentifier): Promise<CacheDocument | null> {\n return this._storage.getDocument(key);\n }\n\n putDocument(\n document: CacheFileDocument,\n resourceCollector: (resourceIdentifier: ExistingRecordIdentifier) => ExistingResourceObject\n ): Promise<void> {\n return this._storage.putDocument(document, resourceCollector);\n }\n\n putResources(\n document: ResourceDataDocument<ExistingRecordIdentifier>,\n resourceCollector: (resourceIdentifier: ExistingRecordIdentifier) => ExistingResourceObject\n ): Promise<void> {\n return this._storage.putResources(document, resourceCollector);\n }\n\n clear(reset?: boolean) {\n return this._storage.clear(reset);\n }\n}\n"],"names":["WARP_DRIVE_STORAGE_FILE_NAME","WARP_DRIVE_STORAGE_VERSION","InternalDocumentStorage","constructor","options","_lastModified","_invalidated","_fileHandle","_open","scope","_channel","Object","assign","BroadcastChannel","onmessage","_onMessage","bind","_event","directoryHandle","navigator","storage","getDirectory","fileHandle","getFileHandle","create","_read","_filePromise","updateFile","file","getFile","lastModified","_cache","contents","text","cache","JSON","parse","documents","resources","Map","cacheMap","_patch","documentKey","document","updatedResources","writable","createWritable","set","forEach","resource","key","entries","cacheFile","write","stringify","close","postMessage","type","keys","getDocument","safeDocumentHydrate","get","lid","content","docHasData","data","Array","isArray","map","resourceIdentifier","Error","structuredClone","included","putDocument","resourceCollector","_getResources","safeDocumentSerialize","putResources","clear","reset","isolated","Storages","delete","macroCondition","getGlobalConfig","WarpDrive","env","DEBUG","test","doc","newDoc","request","prepareRequest","response","prepareResponse","signal","headers","requestCopy","store","AbortSignal","Headers","from","clone","ok","redirected","status","statusText","url","req","Request","resp","Response","DocumentStorage","fileName","has","_storage","deref","WeakRef"],"mappings":"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"}
@@ -131,6 +131,43 @@ class PersistedCache {
131
131
  return this._cache.peek(identifier);
132
132
  }
133
133
 
134
+ /**
135
+ * Peek resource data from the Cache.
136
+ *
137
+ * In development, if the return value
138
+ * is JSON the return value
139
+ * will be deep-cloned and deep-frozen
140
+ * to prevent mutation thereby enforcing cache
141
+ * Immutability.
142
+ *
143
+ * This form of peek is useful for implementations
144
+ * that want to feed raw-data from cache to the UI
145
+ * or which want to interact with a blob of data
146
+ * directly from the presentation cache.
147
+ *
148
+ * An implementation might want to do this because
149
+ * de-referencing records which read from their own
150
+ * blob is generally safer because the record does
151
+ * not require retainining connections to the Store
152
+ * and Cache to present data on a per-field basis.
153
+ *
154
+ * This generally takes the place of `getAttr` as
155
+ * an API and may even take the place of `getRelationship`
156
+ * depending on implementation specifics, though this
157
+ * latter usage is less recommended due to the advantages
158
+ * of the Graph handling necessary entanglements and
159
+ * notifications for relational data.
160
+ *
161
+ * @method peek
162
+ * @internal
163
+ * @param {StableRecordIdentifier | StableDocumentIdentifier} identifier
164
+ * @returns {ResourceDocument | ResourceBlob | null} the known resource data
165
+ */
166
+
167
+ peekRemoteState(identifier) {
168
+ return this._cache.peekRemoteState(identifier);
169
+ }
170
+
134
171
  /**
135
172
  * Peek the Cache for the existing request data associated with
136
173
  * a cacheable request
@@ -353,6 +390,19 @@ class PersistedCache {
353
390
  return this._cache.getAttr(identifier, field);
354
391
  }
355
392
 
393
+ /**
394
+ * Retrieve the remote state for an attribute from the cache
395
+ *
396
+ * @method getAttr
397
+ * @internal
398
+ * @param identifier
399
+ * @param propertyName
400
+ * @return {unknown}
401
+ */
402
+ getRemoteAttr(identifier, field) {
403
+ return this._cache.getRemoteAttr(identifier, field);
404
+ }
405
+
356
406
  /**
357
407
  * Mutate the data for an attribute in the cache
358
408
  *
@@ -477,6 +527,19 @@ class PersistedCache {
477
527
  return this._cache.getRelationship(identifier, field, isCollection);
478
528
  }
479
529
 
530
+ /**
531
+ * Query the remote state for the current state of a relationship property
532
+ *
533
+ * @method getRelationship
534
+ * @internal
535
+ * @param identifier
536
+ * @param propertyName
537
+ * @return resource relationship object
538
+ */
539
+ getRemoteRelationship(identifier, field, isCollection) {
540
+ return this._cache.getRemoteRelationship(identifier, field, isCollection);
541
+ }
542
+
480
543
  // Resource State
481
544
  // ===============
482
545