@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.
- package/CHANGELOG.md +1 -0
- package/LICENSE.md +9 -0
- package/NCC-1701-a-blue.svg +4 -0
- package/NCC-1701-a.svg +4 -0
- package/README.md +33 -0
- package/dist/data-worker.js +281 -0
- package/dist/data-worker.js.map +1 -0
- package/dist/document-storage.js +243 -0
- package/dist/document-storage.js.map +1 -0
- package/dist/persisted-cache.js +559 -0
- package/dist/persisted-cache.js.map +1 -0
- package/dist/worker-fetch.js +149 -0
- package/dist/worker-fetch.js.map +1 -0
- package/package.json +82 -0
- package/unstable-preview-types/data-worker/cache-handler.d.ts +11 -0
- package/unstable-preview-types/data-worker/cache-handler.d.ts.map +1 -0
- package/unstable-preview-types/data-worker/fetch.d.ts +37 -0
- package/unstable-preview-types/data-worker/fetch.d.ts.map +1 -0
- package/unstable-preview-types/data-worker/types.d.ts +34 -0
- package/unstable-preview-types/data-worker/types.d.ts.map +1 -0
- package/unstable-preview-types/data-worker/utils.d.ts +23 -0
- package/unstable-preview-types/data-worker/utils.d.ts.map +1 -0
- package/unstable-preview-types/data-worker/worker.d.ts +16 -0
- package/unstable-preview-types/data-worker/worker.d.ts.map +1 -0
- package/unstable-preview-types/data-worker.d.ts +5 -0
- package/unstable-preview-types/data-worker.d.ts.map +1 -0
- package/unstable-preview-types/document-storage/index.d.ts +90 -0
- package/unstable-preview-types/document-storage/index.d.ts.map +1 -0
- package/unstable-preview-types/document-storage.d.ts +4 -0
- package/unstable-preview-types/document-storage.d.ts.map +1 -0
- package/unstable-preview-types/index.d.ts +13 -0
- package/unstable-preview-types/persisted-cache/cache.d.ts +433 -0
- package/unstable-preview-types/persisted-cache/cache.d.ts.map +1 -0
- package/unstable-preview-types/persisted-cache/db.d.ts +25 -0
- package/unstable-preview-types/persisted-cache/db.d.ts.map +1 -0
- package/unstable-preview-types/persisted-cache/fetch.d.ts +11 -0
- package/unstable-preview-types/persisted-cache/fetch.d.ts.map +1 -0
- package/unstable-preview-types/persisted-cache.d.ts +4 -0
- package/unstable-preview-types/persisted-cache.d.ts.map +1 -0
- package/unstable-preview-types/worker-fetch.d.ts +4 -0
- 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 @@
|
|
|
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" />
|