@warp-drive-mirror/experiments 0.0.1-alpha.97

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (41) hide show
  1. package/CHANGELOG.md +1 -0
  2. package/LICENSE.md +9 -0
  3. package/NCC-1701-a-blue.svg +4 -0
  4. package/NCC-1701-a.svg +4 -0
  5. package/README.md +33 -0
  6. package/dist/data-worker.js +281 -0
  7. package/dist/data-worker.js.map +1 -0
  8. package/dist/document-storage.js +243 -0
  9. package/dist/document-storage.js.map +1 -0
  10. package/dist/persisted-cache.js +559 -0
  11. package/dist/persisted-cache.js.map +1 -0
  12. package/dist/worker-fetch.js +149 -0
  13. package/dist/worker-fetch.js.map +1 -0
  14. package/package.json +82 -0
  15. package/unstable-preview-types/data-worker/cache-handler.d.ts +11 -0
  16. package/unstable-preview-types/data-worker/cache-handler.d.ts.map +1 -0
  17. package/unstable-preview-types/data-worker/fetch.d.ts +37 -0
  18. package/unstable-preview-types/data-worker/fetch.d.ts.map +1 -0
  19. package/unstable-preview-types/data-worker/types.d.ts +34 -0
  20. package/unstable-preview-types/data-worker/types.d.ts.map +1 -0
  21. package/unstable-preview-types/data-worker/utils.d.ts +23 -0
  22. package/unstable-preview-types/data-worker/utils.d.ts.map +1 -0
  23. package/unstable-preview-types/data-worker/worker.d.ts +16 -0
  24. package/unstable-preview-types/data-worker/worker.d.ts.map +1 -0
  25. package/unstable-preview-types/data-worker.d.ts +5 -0
  26. package/unstable-preview-types/data-worker.d.ts.map +1 -0
  27. package/unstable-preview-types/document-storage/index.d.ts +90 -0
  28. package/unstable-preview-types/document-storage/index.d.ts.map +1 -0
  29. package/unstable-preview-types/document-storage.d.ts +4 -0
  30. package/unstable-preview-types/document-storage.d.ts.map +1 -0
  31. package/unstable-preview-types/index.d.ts +13 -0
  32. package/unstable-preview-types/persisted-cache/cache.d.ts +433 -0
  33. package/unstable-preview-types/persisted-cache/cache.d.ts.map +1 -0
  34. package/unstable-preview-types/persisted-cache/db.d.ts +25 -0
  35. package/unstable-preview-types/persisted-cache/db.d.ts.map +1 -0
  36. package/unstable-preview-types/persisted-cache/fetch.d.ts +11 -0
  37. package/unstable-preview-types/persisted-cache/fetch.d.ts.map +1 -0
  38. package/unstable-preview-types/persisted-cache.d.ts +4 -0
  39. package/unstable-preview-types/persisted-cache.d.ts.map +1 -0
  40. package/unstable-preview-types/worker-fetch.d.ts +4 -0
  41. package/unstable-preview-types/worker-fetch.d.ts.map +1 -0
@@ -0,0 +1,149 @@
1
+ import { createDeferred } from '@ember-data-mirror/request';
2
+ import { macroCondition, getGlobalConfig } from '@embroider/macros';
3
+ const isServerEnv = typeof FastBoot !== 'undefined';
4
+ function isAggregateError(error) {
5
+ return error instanceof AggregateError || error.name === 'AggregateError' && Array.isArray(error.errors);
6
+ }
7
+ function stitchTrace(stack, origin) {
8
+ if (origin.startsWith('Error\n')) {
9
+ return origin.slice(6) + '\n' + stack;
10
+ }
11
+ return origin + '\n' + stack;
12
+ }
13
+ function cloneError(error, stack) {
14
+ const isAggregate = isAggregateError(error);
15
+ const cloned = isAggregate ? new AggregateError(structuredClone(error.errors), error.message) : new Error(error.message);
16
+ cloned.stack = stitchTrace(error.stack || '', stack);
17
+ cloned.error = error.error;
18
+
19
+ // copy over enumerable properties
20
+ Object.assign(cloned, error);
21
+ return cloned;
22
+ }
23
+ class WorkerFetch {
24
+ constructor(worker) {
25
+ this.threadId = isServerEnv ? '' : crypto.randomUUID();
26
+ this.pending = new Map();
27
+ const isTesting = macroCondition(getGlobalConfig().WarpDrive.env.TESTING) ? true : false;
28
+ macroCondition(getGlobalConfig().WarpDrive.env.DEBUG) ? (test => {
29
+ if (!test) {
30
+ throw new Error(`Expected a SharedWorker instance`);
31
+ }
32
+ })(isTesting || isServerEnv || worker instanceof SharedWorker) : {};
33
+ this.worker = worker;
34
+ if (!isServerEnv) {
35
+ this.channel = new MessageChannel();
36
+ const port = this.worker instanceof SharedWorker ? this.worker.port : this.worker;
37
+ port.postMessage({
38
+ type: 'connect',
39
+ thread: this.threadId
40
+ }, [this.channel.port2]);
41
+ this.channel.port1.onmessage = event => {
42
+ const {
43
+ type,
44
+ id,
45
+ data
46
+ } = event.data;
47
+ const info = this.cleanupRequest(id);
48
+
49
+ // typically this means the request was aborted
50
+ if (!info) {
51
+ return;
52
+ }
53
+ if (type === 'success-response') {
54
+ const {
55
+ deferred
56
+ } = info;
57
+ const {
58
+ response,
59
+ content
60
+ } = data;
61
+ if (response) {
62
+ response.headers = new Headers(response.headers);
63
+ info.context.setResponse(new Response(null, response));
64
+ }
65
+ deferred.resolve(content);
66
+ return;
67
+ }
68
+ if (type === 'error-response') {
69
+ const {
70
+ deferred,
71
+ stack
72
+ } = info;
73
+ deferred.reject(cloneError(data, stack));
74
+ return;
75
+ }
76
+ };
77
+ }
78
+ }
79
+ cleanupRequest(id) {
80
+ const info = this.pending.get(id);
81
+ this.pending.delete(id);
82
+ if (info?.signal) {
83
+ info.signal.removeEventListener('abort', info.abortFn);
84
+ }
85
+ return info;
86
+ }
87
+ send(event) {
88
+ this.channel.port1.postMessage(event);
89
+ }
90
+ request(context, next) {
91
+ if (isServerEnv) {
92
+ return next(context.request);
93
+ }
94
+ const deferred = createDeferred();
95
+ const {
96
+ signal,
97
+ request
98
+ } = prepareRequest(context.request);
99
+ const abortFn = signal ? () => {
100
+ deferred.reject(enhanceReason(signal.reason));
101
+ this.send({
102
+ type: 'abort',
103
+ thread: this.threadId,
104
+ id: context.id,
105
+ data: signal.reason
106
+ });
107
+ this.cleanupRequest(context.id);
108
+ } : () => {
109
+ return;
110
+ };
111
+ signal?.addEventListener('abort', abortFn);
112
+ try {
113
+ throw new Error();
114
+ } catch (e) {
115
+ this.pending.set(context.id, {
116
+ context,
117
+ deferred,
118
+ signal,
119
+ abortFn,
120
+ stack: e.stack
121
+ });
122
+ }
123
+ this.send({
124
+ type: 'request',
125
+ thread: this.threadId,
126
+ id: context.id,
127
+ data: request
128
+ });
129
+ return deferred.promise;
130
+ }
131
+ }
132
+ function enhanceReason(reason) {
133
+ return new DOMException(reason || 'The user aborted a request.', 'AbortError');
134
+ }
135
+ function prepareRequest(request) {
136
+ const {
137
+ signal
138
+ } = request;
139
+ const requestCopy = Object.assign({}, request);
140
+ delete requestCopy.store;
141
+ if (signal instanceof AbortSignal) {
142
+ delete requestCopy.signal;
143
+ }
144
+ return {
145
+ signal: signal || null,
146
+ request: requestCopy
147
+ };
148
+ }
149
+ export { WorkerFetch };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"worker-fetch.js","sources":["../src/data-worker/fetch.ts"],"sourcesContent":["import type { RequestInfo } from '@ember-data-mirror/request';\nimport { createDeferred } from '@ember-data-mirror/request';\nimport type { Context } from '@ember-data-mirror/request/-private/context';\nimport type { Deferred, Future, NextFn } 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';\nimport type { ApiError } from '@warp-drive-mirror/core-types/spec/error';\n\nimport type { AbortEventData, MainThreadEvent, RequestEventData } from './types';\n\nexport interface FastBoot {\n require(moduleName: string): unknown;\n isFastBoot: boolean;\n request: Request;\n}\n\ndeclare global {\n const FastBoot: undefined | FastBoot;\n}\n\nconst isServerEnv = typeof FastBoot !== 'undefined';\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\nfunction stitchTrace(stack: string, origin: string) {\n if (origin.startsWith('Error\\n')) {\n return origin.slice(6) + '\\n' + stack;\n }\n return origin + '\\n' + stack;\n}\n\nfunction cloneError(error: RobustError, stack: string) {\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 = stitchTrace(error.stack || '', stack);\n cloned.error = error.error;\n\n // copy over enumerable properties\n Object.assign(cloned, error);\n\n return cloned;\n}\n\nexport class WorkerFetch {\n declare worker: Worker | SharedWorker;\n declare threadId: string;\n declare pending: Map<\n number,\n { context: Context; signal: AbortSignal | null; abortFn: () => void; deferred: Deferred<unknown>; stack: string }\n >;\n declare channel: MessageChannel;\n\n constructor(worker: Worker | SharedWorker | null) {\n this.threadId = isServerEnv ? '' : crypto.randomUUID();\n this.pending = 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 this.channel = new MessageChannel();\n\n const port = this.worker instanceof SharedWorker ? this.worker.port : this.worker;\n port.postMessage({ type: 'connect', thread: this.threadId }, [this.channel.port2]);\n\n this.channel.port1.onmessage = (event: MainThreadEvent<unknown>) => {\n const { type, id, data } = event.data;\n const info = this.cleanupRequest(id);\n\n // typically this means the request was aborted\n if (!info) {\n return;\n }\n\n if (type === 'success-response') {\n const { deferred } = info;\n\n const { response, content } = data;\n\n if (response) {\n (response as { headers: Headers }).headers = new Headers(response.headers);\n info.context.setResponse(new Response(null, response));\n }\n\n deferred.resolve(content);\n return;\n }\n\n if (type === 'error-response') {\n const { deferred, stack } = info;\n\n deferred.reject(cloneError(data, stack));\n return;\n }\n };\n }\n }\n\n cleanupRequest(id: number) {\n const info = this.pending.get(id);\n this.pending.delete(id);\n\n if (info?.signal) {\n info.signal.removeEventListener('abort', info.abortFn);\n }\n\n return info;\n }\n\n send(event: RequestEventData | AbortEventData) {\n this.channel.port1.postMessage(event);\n }\n\n request<T>(context: Context, next: NextFn<T>): Promise<T> | Future<T> {\n if (isServerEnv) {\n return next(context.request);\n }\n\n const deferred = createDeferred<T>();\n const { signal, request } = prepareRequest(context.request);\n const abortFn = signal\n ? () => {\n deferred.reject(enhanceReason(signal.reason as string));\n this.send({ type: 'abort', thread: this.threadId, id: context.id, data: signal.reason as string });\n this.cleanupRequest(context.id);\n }\n : () => {\n return;\n };\n\n signal?.addEventListener('abort', abortFn);\n\n try {\n throw new Error();\n } catch (e: unknown) {\n this.pending.set(context.id, {\n context,\n deferred,\n signal,\n abortFn,\n stack: (e as Error).stack!,\n });\n }\n\n this.send({\n type: 'request',\n thread: this.threadId,\n id: context.id,\n data: request,\n });\n\n return deferred.promise;\n }\n}\n\nexport function enhanceReason(reason?: string) {\n return new DOMException(reason || 'The user aborted a request.', 'AbortError');\n}\n\nfunction prepareRequest(request: Context['request']): { signal: AbortSignal | null; request: RequestInfo } {\n const { signal } = 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 return { signal: signal || null, request: requestCopy };\n}\n"],"names":["isServerEnv","FastBoot","isAggregateError","error","AggregateError","name","Array","isArray","errors","stitchTrace","stack","origin","startsWith","slice","cloneError","isAggregate","cloned","structuredClone","message","Error","Object","assign","WorkerFetch","constructor","worker","threadId","crypto","randomUUID","pending","Map","isTesting","macroCondition","getGlobalConfig","WarpDrive","env","TESTING","DEBUG","test","SharedWorker","channel","MessageChannel","port","postMessage","type","thread","port2","port1","onmessage","event","id","data","info","cleanupRequest","deferred","response","content","headers","Headers","context","setResponse","Response","resolve","reject","get","delete","signal","removeEventListener","abortFn","send","request","next","createDeferred","prepareRequest","enhanceReason","reason","addEventListener","e","set","promise","DOMException","requestCopy","store","AbortSignal"],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,82 @@
1
+ {
2
+ "name": "@warp-drive-mirror/experiments",
3
+ "description": "Experimental features for EmberData/WarpDrive",
4
+ "version": "0.0.1-alpha.97",
5
+ "license": "MIT",
6
+ "author": "Chris Thoburn <runspired@users.noreply.github.com>",
7
+ "repository": {
8
+ "type": "git",
9
+ "url": "git+ssh://git@github.com:emberjs/data.git",
10
+ "directory": "packages/experiments"
11
+ },
12
+ "homepage": "https://github.com/emberjs/data",
13
+ "bugs": "https://github.com/emberjs/data/issues",
14
+ "exports": {
15
+ "./persisted-cache": {
16
+ "default": "./dist/persisted-cache.js"
17
+ },
18
+ "./document-storage": {
19
+ "default": "./dist/document-storage.js"
20
+ },
21
+ "./data-worker": {
22
+ "default": "./dist/data-worker.js"
23
+ },
24
+ "./worker-fetch": {
25
+ "default": "./dist/worker-fetch.js"
26
+ }
27
+ },
28
+ "files": [
29
+ "dist",
30
+ "unstable-preview-types",
31
+ "CHANGELOG.md",
32
+ "README.md",
33
+ "LICENSE.md",
34
+ "NCC-1701-a-blue.svg",
35
+ "NCC-1701-a.svg"
36
+ ],
37
+ "scripts": {
38
+ "lint": "eslint . --quiet --cache --cache-strategy=content --report-unused-disable-directives",
39
+ "build:pkg": "vite build;",
40
+ "sync-hardlinks": "bun run sync-dependencies-meta-injected"
41
+ },
42
+ "peerDependencies": {
43
+ "@sqlite.org/sqlite-wasm": "3.46.0-build2",
44
+ "@ember-data-mirror/request": "5.4.0-alpha.97",
45
+ "@ember-data-mirror/request-utils": "5.4.0-alpha.97",
46
+ "@ember-data-mirror/store": "5.4.0-alpha.97",
47
+ "@warp-drive-mirror/core-types": "0.0.0-alpha.83"
48
+ },
49
+ "peerDependenciesMeta": {
50
+ "@sqlite.org/sqlite-wasm": {
51
+ "optional": true
52
+ }
53
+ },
54
+ "dependencies": {
55
+ "@embroider/macros": "^1.16.1",
56
+ "@warp-drive-mirror/build-config": "0.0.0-alpha.34"
57
+ },
58
+ "devDependencies": {
59
+ "@babel/core": "^7.24.5",
60
+ "@babel/plugin-transform-typescript": "^7.24.5",
61
+ "@babel/preset-env": "^7.24.5",
62
+ "@babel/preset-typescript": "^7.24.1",
63
+ "@ember-data-mirror/request": "5.4.0-alpha.97",
64
+ "@ember-data-mirror/request-utils": "5.4.0-alpha.97",
65
+ "@ember-data-mirror/store": "5.4.0-alpha.97",
66
+ "@ember-data-mirror/tracking": "5.4.0-alpha.97",
67
+ "@glimmer/component": "^1.1.2",
68
+ "@warp-drive-mirror/core-types": "0.0.0-alpha.83",
69
+ "@warp-drive/internal-config": "5.4.0-alpha.97",
70
+ "ember-source": "~5.8.0",
71
+ "pnpm-sync-dependencies-meta-injected": "0.0.14",
72
+ "@sqlite.org/sqlite-wasm": "3.46.0-build2",
73
+ "typescript": "^5.4.5",
74
+ "vite": "^5.2.11"
75
+ },
76
+ "engines": {
77
+ "node": ">= 18.20.3"
78
+ },
79
+ "volta": {
80
+ "extends": "../../../../../../package.json"
81
+ }
82
+ }
@@ -0,0 +1,11 @@
1
+ declare module '@warp-drive-mirror/experiments/data-worker/cache-handler' {
2
+ import type { CacheHandler as CacheHandlerType } from '@ember-data-mirror/request';
3
+ /**
4
+ * A simplified CacheHandler that hydrates ResourceDataDocuments from the cache
5
+ * with their referenced resources.
6
+ *
7
+ * @typedoc
8
+ */
9
+ export const CacheHandler: CacheHandlerType;
10
+ }
11
+ //# sourceMappingURL=cache-handler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cache-handler.d.ts","sourceRoot":"","sources":["../../src/data-worker/cache-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,IAAI,gBAAgB,EAAkB,MAAM,qBAAqB,CAAC;AAY5F;;;;;GAKG;AACH,eAAO,MAAM,YAAY,EAAE,gBA0B1B,CAAC"}
@@ -0,0 +1,37 @@
1
+ declare module '@warp-drive-mirror/experiments/data-worker/fetch' {
2
+ import type { Context } from '@ember-data-mirror/request/-private/context';
3
+ import type { Deferred, Future, NextFn } from '@ember-data-mirror/request/-private/types';
4
+ import type { AbortEventData, RequestEventData } from '@warp-drive-mirror/experiments/data-worker/types';
5
+ export interface FastBoot {
6
+ require(moduleName: string): unknown;
7
+ isFastBoot: boolean;
8
+ request: Request;
9
+ }
10
+ global {
11
+ const FastBoot: undefined | FastBoot;
12
+ }
13
+ export class WorkerFetch {
14
+ worker: Worker | SharedWorker;
15
+ threadId: string;
16
+ pending: Map<number, {
17
+ context: Context;
18
+ signal: AbortSignal | null;
19
+ abortFn: () => void;
20
+ deferred: Deferred<unknown>;
21
+ stack: string;
22
+ }>;
23
+ channel: MessageChannel;
24
+ constructor(worker: Worker | SharedWorker | null);
25
+ cleanupRequest(id: number): {
26
+ context: Context;
27
+ signal: AbortSignal | null;
28
+ abortFn: () => void;
29
+ deferred: Deferred<unknown>;
30
+ stack: string;
31
+ } | undefined;
32
+ send(event: RequestEventData | AbortEventData): void;
33
+ request<T>(context: Context, next: NextFn<T>): Promise<T> | Future<T>;
34
+ }
35
+ export function enhanceReason(reason?: string): DOMException;
36
+ }
37
+ //# sourceMappingURL=fetch.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fetch.d.ts","sourceRoot":"","sources":["../../src/data-worker/fetch.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,sCAAsC,CAAC;AACpE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,oCAAoC,CAAC;AAKnF,OAAO,KAAK,EAAE,cAAc,EAAmB,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAEjF,MAAM,WAAW,QAAQ;IACvB,OAAO,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC;IACrC,UAAU,EAAE,OAAO,CAAC;IACpB,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,MAAM,QAAQ,EAAE,SAAS,GAAG,QAAQ,CAAC;CACtC;AAgCD,qBAAa,WAAW;IACd,MAAM,EAAE,MAAM,GAAG,YAAY,CAAC;IAC9B,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,GAAG,CAClB,MAAM,EACN;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,MAAM,EAAE,WAAW,GAAG,IAAI,CAAC;QAAC,OAAO,EAAE,MAAM,IAAI,CAAC;QAAC,QAAQ,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAClH,CAAC;IACM,OAAO,EAAE,cAAc,CAAC;gBAEpB,MAAM,EAAE,MAAM,GAAG,YAAY,GAAG,IAAI;IA+ChD,cAAc,CAAC,EAAE,EAAE,MAAM;;;;;;;IAWzB,IAAI,CAAC,KAAK,EAAE,gBAAgB,GAAG,cAAc;IAI7C,OAAO,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC;CAwCtE;AAED,wBAAgB,aAAa,CAAC,MAAM,CAAC,EAAE,MAAM,gBAE5C"}
@@ -0,0 +1,34 @@
1
+ declare module '@warp-drive-mirror/experiments/data-worker/types' {
2
+ import type { RequestInfo, StructuredDataDocument, StructuredErrorDocument } from '@ember-data-mirror/request';
3
+ export type SuccessResponseEventData<T> = {
4
+ type: 'success-response';
5
+ thread: string;
6
+ id: number;
7
+ data: StructuredDataDocument<T>;
8
+ };
9
+ export type ErrorResponseEventData<T> = {
10
+ type: 'error-response';
11
+ thread: string;
12
+ id: number;
13
+ data: StructuredErrorDocument<T>;
14
+ };
15
+ export type RequestEventData = {
16
+ type: 'request';
17
+ thread: string;
18
+ id: number;
19
+ data: RequestInfo;
20
+ };
21
+ export type AbortEventData = {
22
+ type: 'abort';
23
+ thread: string;
24
+ id: number;
25
+ data: string;
26
+ };
27
+ export type ThreadInitEventData = {
28
+ type: 'connect';
29
+ thread: string;
30
+ };
31
+ export type MainThreadEvent<T> = MessageEvent<SuccessResponseEventData<T> | ErrorResponseEventData<T>>;
32
+ export type WorkerThreadEvent = MessageEvent<RequestEventData> | MessageEvent<ThreadInitEventData> | MessageEvent<AbortEventData>;
33
+ }
34
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/data-worker/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,sBAAsB,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAC;AAExG,MAAM,MAAM,wBAAwB,CAAC,CAAC,IAAI;IACxC,IAAI,EAAE,kBAAkB,CAAC;IACzB,MAAM,EAAE,MAAM,CAAC;IACf,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,sBAAsB,CAAC,CAAC,CAAC,CAAC;CACjC,CAAC;AACF,MAAM,MAAM,sBAAsB,CAAC,CAAC,IAAI;IACtC,IAAI,EAAE,gBAAgB,CAAC;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,uBAAuB,CAAC,CAAC,CAAC,CAAC;CAClC,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,IAAI,EAAE,SAAS,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,WAAW,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG;IAC3B,IAAI,EAAE,OAAO,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,IAAI,EAAE,SAAS,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,MAAM,MAAM,eAAe,CAAC,CAAC,IAAI,YAAY,CAAC,wBAAwB,CAAC,CAAC,CAAC,GAAG,sBAAsB,CAAC,CAAC,CAAC,CAAC,CAAC;AACvG,MAAM,MAAM,iBAAiB,GACzB,YAAY,CAAC,gBAAgB,CAAC,GAC9B,YAAY,CAAC,mBAAmB,CAAC,GACjC,YAAY,CAAC,cAAc,CAAC,CAAC"}
@@ -0,0 +1,23 @@
1
+ declare module '@warp-drive-mirror/experiments/data-worker/utils' {
2
+ import type Store from '@ember-data-mirror/store';
3
+ import type { StableDocumentIdentifier } from '@warp-drive-mirror/core-types/identifier';
4
+ import type { ImmutableCreateRequestOptions, ImmutableDeleteRequestOptions, ImmutableRequestInfo, ImmutableUpdateRequestOptions, StructuredDataDocument } from '@warp-drive-mirror/core-types/request';
5
+ import type { ApiError } from '@warp-drive-mirror/core-types/spec/error';
6
+ export const MUTATION_OPS: Set<string>;
7
+ /**
8
+ * In a Worker, any time we are asked to make a request, data needs to be returned.
9
+ * background requests are ergo no different than foreground requests.
10
+ * @internal
11
+ */
12
+ export function calcShouldFetch(store: Store, request: ImmutableRequestInfo, hasCachedValue: boolean, identifier: StableDocumentIdentifier | null): boolean;
13
+ export function isMutation(request: Partial<ImmutableRequestInfo>): request is ImmutableUpdateRequestOptions | ImmutableCreateRequestOptions | ImmutableDeleteRequestOptions;
14
+ export function isCacheAffecting<T>(document: StructuredDataDocument<T>): boolean;
15
+ type RobustError = Error & {
16
+ error: string | object;
17
+ errors?: ApiError[];
18
+ content?: unknown;
19
+ };
20
+ export function cloneError(error: RobustError): RobustError;
21
+ export {};
22
+ }
23
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/data-worker/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,mBAAmB,CAAC;AAC3C,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,mCAAmC,CAAC;AAClF,OAAO,KAAK,EACV,6BAA6B,EAC7B,6BAA6B,EAC7B,oBAAoB,EACpB,6BAA6B,EAC7B,sBAAsB,EACvB,MAAM,gCAAgC,CAAC;AACxC,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mCAAmC,CAAC;AAElE,eAAO,MAAM,YAAY,aAA4D,CAAC;AAEtF;;;;GAIG;AACH,wBAAgB,eAAe,CAC7B,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,oBAAoB,EAC7B,cAAc,EAAE,OAAO,EACvB,UAAU,EAAE,wBAAwB,GAAG,IAAI,GAC1C,OAAO,CAWT;AAED,wBAAgB,UAAU,CACxB,OAAO,EAAE,OAAO,CAAC,oBAAoB,CAAC,GACrC,OAAO,IAAI,6BAA6B,GAAG,6BAA6B,GAAG,6BAA6B,CAE1G;AAED,wBAAgB,gBAAgB,CAAC,CAAC,EAAE,QAAQ,EAAE,sBAAsB,CAAC,CAAC,CAAC,GAAG,OAAO,CAahF;AAMD,KAAK,WAAW,GAAG,KAAK,GAAG;IAAE,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,QAAQ,EAAE,CAAC;IAAC,OAAO,CAAC,EAAE,OAAO,CAAA;CAAE,CAAC;AAG9F,wBAAgB,UAAU,CAAC,KAAK,EAAE,WAAW,eAa5C"}
@@ -0,0 +1,16 @@
1
+ declare module '@warp-drive-mirror/experiments/data-worker/worker' {
2
+ import type { Future } from '@ember-data-mirror/request';
3
+ import type Store from '@ember-data-mirror/store';
4
+ import type { AbortEventData, RequestEventData } from '@warp-drive-mirror/experiments/data-worker/types';
5
+ export class DataWorker {
6
+ store: Store;
7
+ threads: Map<string, MessagePort>;
8
+ pending: Map<string, Map<number, Future<unknown>>>;
9
+ constructor(UserStore: typeof Store);
10
+ initialize(): void;
11
+ setupThread(thread: string, port: MessagePort): void;
12
+ abortRequest(event: AbortEventData): void;
13
+ request(event: RequestEventData): Promise<void>;
14
+ }
15
+ }
16
+ //# sourceMappingURL=worker.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"worker.d.ts","sourceRoot":"","sources":["../../src/data-worker/worker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAwC,MAAM,qBAAqB,CAAC;AACxF,OAAO,KAAK,KAAK,MAAM,mBAAmB,CAAC;AAE3C,OAAO,KAAK,EAAE,cAAc,EAAE,gBAAgB,EAA0C,MAAM,SAAS,CAAC;AAExG,qBAAa,UAAU;IACb,KAAK,EAAE,KAAK,CAAC;IACb,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAClC,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBAE/C,SAAS,EAAE,OAAO,KAAK;IAOnC,UAAU;IAYV,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW;IAqB7C,YAAY,CAAC,KAAK,EAAE,cAAc;IAU5B,OAAO,CAAC,KAAK,EAAE,gBAAgB;CAkBtC"}
@@ -0,0 +1,5 @@
1
+ declare module '@warp-drive-mirror/experiments/data-worker' {
2
+ export { DataWorker } from '@warp-drive-mirror/experiments/data-worker/worker';
3
+ export { CacheHandler } from '@warp-drive-mirror/experiments/data-worker/cache-handler';
4
+ }
5
+ //# sourceMappingURL=data-worker.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-worker.d.ts","sourceRoot":"","sources":["../src/data-worker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC"}
@@ -0,0 +1,90 @@
1
+ declare module '@warp-drive-mirror/experiments/document-storage' {
2
+ import type { StructuredDocument } from '@ember-data-mirror/request';
3
+ import type { ExistingRecordIdentifier } from '@warp-drive-mirror/core-types/identifier';
4
+ import type { ResourceDocument } from '@warp-drive-mirror/core-types/spec/document';
5
+ import type { ExistingResourceObject } from '@warp-drive-mirror/core-types/spec/json-api-raw';
6
+ export const WARP_DRIVE_STORAGE_FILE_NAME = "warp-drive_document-storage";
7
+ export const WARP_DRIVE_STORAGE_VERSION = 1;
8
+ export type DocumentStorageOptions = {
9
+ /**
10
+ * The scope of the storage. This is used to enable multiple distinct
11
+ * storage areas within the same origin.
12
+ *
13
+ * One use case for this is to have a separate storage area for each
14
+ * user credential. So for instance, in applications that allow a single
15
+ * user to have multiple accounts, each account can have its own storage!
16
+ */
17
+ scope: string;
18
+ /**
19
+ * When set to true, if other instances of the storage are created with
20
+ * the same scope, they will not share the same in-memory cache and BroadcastChannel.
21
+ *
22
+ * This is mostly useful for testing purposes to replicate the behavior of
23
+ * multiple tabs or workers.
24
+ */
25
+ isolated: boolean;
26
+ };
27
+ /**
28
+ * DocumentStorage is specifically designed around WarpDrive Cache and Request concepts.
29
+ *
30
+ * CacheFileDocument is a StructuredDocument (request response) whose `content` is
31
+ * the ResourceDocument returned by inserting the request into a Store's Cache.
32
+ */
33
+ type CacheFileDocument = StructuredDocument<ResourceDocument<ExistingRecordIdentifier>>;
34
+ /**
35
+ * A CacheDocument is a reconstructed request response that rehydrates ResourceDocument
36
+ * with the associated resources based on their identifiers.
37
+ */
38
+ type CacheDocument = StructuredDocument<ResourceDocument<ExistingResourceObject>>;
39
+ type DocumentIdentifier = {
40
+ lid: string;
41
+ };
42
+ type MemCache = {
43
+ documents: Map<string, CacheFileDocument>;
44
+ resources: Map<string, ExistingResourceObject>;
45
+ };
46
+ class InternalDocumentStorage {
47
+ readonly options: DocumentStorageOptions;
48
+ _fileHandle: Promise<FileSystemFileHandle>;
49
+ _channel: BroadcastChannel;
50
+ _invalidated: boolean;
51
+ _lastModified: number;
52
+ _cache: MemCache | null;
53
+ _filePromise: Promise<MemCache> | null;
54
+ constructor(options: DocumentStorageOptions);
55
+ _onMessage(_event: MessageEvent): void;
56
+ _open(scope: string): Promise<FileSystemFileHandle>;
57
+ _read(): Promise<MemCache>;
58
+ _patch(documentKey: string, document: CacheFileDocument, updatedResources: Map<string, ExistingResourceObject>): Promise<void>;
59
+ getDocument(key: DocumentIdentifier): Promise<CacheDocument | null>;
60
+ putDocument(document: CacheFileDocument, resourceCollector: (resourceIdentifier: ExistingRecordIdentifier) => ExistingResourceObject): Promise<void>;
61
+ clear(reset?: boolean): Promise<void>;
62
+ }
63
+ /**
64
+ * DocumentStorage is a wrapper around the StorageManager API that provides
65
+ * a simple interface for reading and updating documents and requests.
66
+ *
67
+ * Some goals for this experiment:
68
+ *
69
+ * - optimize for storing requests/documents
70
+ * - optimize for storing resources
71
+ * - optimize for looking up resources associated to a document
72
+ * - optimize for notifying cross-tab when data is updated
73
+ *
74
+ * optional features:
75
+ *
76
+ * - support for offline mode
77
+ * - ?? support for relationship based cache traversal
78
+ * - a way to index records by type + another field (e.g updatedAt/createAt/name)
79
+ * such that simple queries can be done without having to scan all records
80
+ */
81
+ export class DocumentStorage {
82
+ readonly _storage: InternalDocumentStorage;
83
+ constructor(options?: Partial<DocumentStorageOptions>);
84
+ getDocument(key: DocumentIdentifier): Promise<CacheDocument | null>;
85
+ putDocument(document: CacheFileDocument, resourceCollector: (resourceIdentifier: ExistingRecordIdentifier) => ExistingResourceObject): Promise<void>;
86
+ clear(reset?: boolean): Promise<void>;
87
+ }
88
+ export {};
89
+ }
90
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/document-storage/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAC9D,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,mCAAmC,CAAC;AAClF,OAAO,KAAK,EAAwB,gBAAgB,EAAE,MAAM,sCAAsC,CAAC;AACnG,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,0CAA0C,CAAC;AAEvF,eAAO,MAAM,4BAA4B,gCAAgC,CAAC;AAC1E,eAAO,MAAM,0BAA0B,IAAI,CAAC;AAE5C,MAAM,MAAM,sBAAsB,GAAG;IACnC;;;;;;;OAOG;IACH,KAAK,EAAE,MAAM,CAAC;IACd;;;;;;OAMG;IACH,QAAQ,EAAE,OAAO,CAAC;CACnB,CAAC;AACF;;;;;GAKG;AACH,KAAK,iBAAiB,GAAG,kBAAkB,CAAC,gBAAgB,CAAC,wBAAwB,CAAC,CAAC,CAAC;AACxF;;;GAGG;AACH,KAAK,aAAa,GAAG,kBAAkB,CAAC,gBAAgB,CAAC,sBAAsB,CAAC,CAAC,CAAC;AAMlF,KAAK,kBAAkB,GAAG;IAAE,GAAG,EAAE,MAAM,CAAA;CAAE,CAAC;AAE1C,KAAK,QAAQ,GAAG;IACd,SAAS,EAAE,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;IAC1C,SAAS,EAAE,GAAG,CAAC,MAAM,EAAE,sBAAsB,CAAC,CAAC;CAChD,CAAC;AAEF,cAAM,uBAAuB;IAC3B,SAAiB,OAAO,EAAE,sBAAsB,CAAC;IACzC,WAAW,EAAE,OAAO,CAAC,oBAAoB,CAAC,CAAC;IAC3C,QAAQ,EAAE,gBAAgB,CAAC;IAC3B,YAAY,EAAE,OAAO,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,QAAQ,GAAG,IAAI,CAAC;IACxB,YAAY,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC;gBAEnC,OAAO,EAAE,sBAAsB;IAW3C,UAAU,CAAC,MAAM,EAAE,YAAY;IAIzB,KAAK,CAAC,KAAK,EAAE,MAAM;IAMnB,KAAK,IAAI,OAAO,CAAC,QAAQ,CAAC;IAmC1B,MAAM,CACV,WAAW,EAAE,MAAM,EACnB,QAAQ,EAAE,iBAAiB,EAC3B,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,sBAAsB,CAAC;IAwBjD,WAAW,CAAC,GAAG,EAAE,kBAAkB,GAAG,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC;IAqDnE,WAAW,CACf,QAAQ,EAAE,iBAAiB,EAC3B,iBAAiB,EAAE,CAAC,kBAAkB,EAAE,wBAAwB,KAAK,sBAAsB,GAC1F,OAAO,CAAC,IAAI,CAAC;IAiCV,KAAK,CAAC,KAAK,CAAC,EAAE,OAAO;CAqB5B;AAQD;;;;;;;;;;;;;;;;;GAiBG;AACH,qBAAa,eAAe;IAC1B,SAAiB,QAAQ,EAAE,uBAAuB,CAAC;gBAEvC,OAAO,GAAE,OAAO,CAAC,sBAAsB,CAAM;IAoBzD,WAAW,CAAC,GAAG,EAAE,kBAAkB,GAAG,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC;IAInE,WAAW,CACT,QAAQ,EAAE,iBAAiB,EAC3B,iBAAiB,EAAE,CAAC,kBAAkB,EAAE,wBAAwB,KAAK,sBAAsB,GAC1F,OAAO,CAAC,IAAI,CAAC;IAIhB,KAAK,CAAC,KAAK,CAAC,EAAE,OAAO;CAGtB"}
@@ -0,0 +1,4 @@
1
+ declare module '@warp-drive-mirror/experiments/document-storage' {
2
+ export { DocumentStorage } from '@warp-drive-mirror/experiments/document-storage/index';
3
+ }
4
+ //# sourceMappingURL=document-storage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"document-storage.d.ts","sourceRoot":"","sources":["../src/document-storage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC"}
@@ -0,0 +1,13 @@
1
+ /// <reference path="./worker-fetch.d.ts" />
2
+ /// <reference path="./document-storage.d.ts" />
3
+ /// <reference path="./data-worker.d.ts" />
4
+ /// <reference path="./persisted-cache.d.ts" />
5
+ /// <reference path="./document-storage/index.d.ts" />
6
+ /// <reference path="./data-worker/cache-handler.d.ts" />
7
+ /// <reference path="./data-worker/fetch.d.ts" />
8
+ /// <reference path="./data-worker/utils.d.ts" />
9
+ /// <reference path="./data-worker/worker.d.ts" />
10
+ /// <reference path="./data-worker/types.d.ts" />
11
+ /// <reference path="./persisted-cache/fetch.d.ts" />
12
+ /// <reference path="./persisted-cache/cache.d.ts" />
13
+ /// <reference path="./persisted-cache/db.d.ts" />