@livestore/adapter-node 0.0.0-snapshot-a953343ad2d7468c6573bcb5e26f0eab4302078f
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/.tsbuildinfo +1 -0
- package/dist/client-session/index.d.ts +23 -0
- package/dist/client-session/index.d.ts.map +1 -0
- package/dist/client-session/index.js +140 -0
- package/dist/client-session/index.js.map +1 -0
- package/dist/devtools/devtools-server.d.ts +16 -0
- package/dist/devtools/devtools-server.d.ts.map +1 -0
- package/dist/devtools/devtools-server.js +58 -0
- package/dist/devtools/devtools-server.js.map +1 -0
- package/dist/devtools/mod.d.ts +3 -0
- package/dist/devtools/mod.d.ts.map +1 -0
- package/dist/devtools/mod.js +2 -0
- package/dist/devtools/mod.js.map +1 -0
- package/dist/devtools/vite-dev-server.d.ts +7 -0
- package/dist/devtools/vite-dev-server.d.ts.map +1 -0
- package/dist/devtools/vite-dev-server.js +107 -0
- package/dist/devtools/vite-dev-server.js.map +1 -0
- package/dist/in-memory/index.d.ts +11 -0
- package/dist/in-memory/index.d.ts.map +1 -0
- package/dist/in-memory/index.js +71 -0
- package/dist/in-memory/index.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -0
- package/dist/leader-thread-lazy.d.ts +2 -0
- package/dist/leader-thread-lazy.d.ts.map +1 -0
- package/dist/leader-thread-lazy.js +10 -0
- package/dist/leader-thread-lazy.js.map +1 -0
- package/dist/make-leader-worker.d.ts +20 -0
- package/dist/make-leader-worker.d.ts.map +1 -0
- package/dist/make-leader-worker.js +151 -0
- package/dist/make-leader-worker.js.map +1 -0
- package/dist/shutdown-channel.d.ts +6 -0
- package/dist/shutdown-channel.d.ts.map +1 -0
- package/dist/shutdown-channel.js +7 -0
- package/dist/shutdown-channel.js.map +1 -0
- package/dist/thread-polyfill.d.ts +2 -0
- package/dist/thread-polyfill.d.ts.map +1 -0
- package/dist/thread-polyfill.js +3 -0
- package/dist/thread-polyfill.js.map +1 -0
- package/dist/webchannel.d.ts +6 -0
- package/dist/webchannel.d.ts.map +1 -0
- package/dist/webchannel.js +33 -0
- package/dist/webchannel.js.map +1 -0
- package/dist/worker-schema.d.ts +196 -0
- package/dist/worker-schema.d.ts.map +1 -0
- package/dist/worker-schema.js +161 -0
- package/dist/worker-schema.js.map +1 -0
- package/package.json +54 -0
- package/rollup.config.mjs +24 -0
- package/src/client-session/index.ts +295 -0
- package/src/devtools/devtools-server.ts +88 -0
- package/src/devtools/mod.ts +2 -0
- package/src/devtools/types.d.ts +33 -0
- package/src/devtools/vite-dev-server.ts +122 -0
- package/src/in-memory/index.ts +133 -0
- package/src/index.ts +2 -0
- package/src/leader-thread-lazy.ts +9 -0
- package/src/make-leader-worker.ts +285 -0
- package/src/shutdown-channel.ts +9 -0
- package/src/thread-polyfill.ts +1 -0
- package/src/webchannel.ts +54 -0
- package/src/worker-schema.ts +175 -0
- package/tsconfig.json +17 -0
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { Adapter } from '@livestore/common';
|
|
2
|
+
export interface NodeAdapterOptions {
|
|
3
|
+
/**
|
|
4
|
+
* Example: `new URL('./livestore.worker.js', import.meta.url)`
|
|
5
|
+
*/
|
|
6
|
+
workerUrl: URL;
|
|
7
|
+
/** Needed for the worker and the devtools */
|
|
8
|
+
schemaPath: string;
|
|
9
|
+
/** Where to store the database files */
|
|
10
|
+
baseDirectory?: string;
|
|
11
|
+
/** The default is the hostname of the current machine */
|
|
12
|
+
clientId?: string;
|
|
13
|
+
devtools?: {
|
|
14
|
+
/**
|
|
15
|
+
* Where to run the devtools server (via Vite)
|
|
16
|
+
*
|
|
17
|
+
* @default 4242
|
|
18
|
+
*/
|
|
19
|
+
port: number;
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
export declare const makeNodeAdapter: ({ workerUrl, schemaPath, baseDirectory, devtools: devtoolsOptions, clientId, }: NodeAdapterOptions) => Adapter;
|
|
23
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/client-session/index.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,OAAO,EAMR,MAAM,mBAAmB,CAAA;AAsB1B,MAAM,WAAW,kBAAkB;IACjC;;OAEG;IACH,SAAS,EAAE,GAAG,CAAA;IACd,6CAA6C;IAC7C,UAAU,EAAE,MAAM,CAAA;IAClB,wCAAwC;IACxC,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,yDAAyD;IACzD,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,QAAQ,CAAC,EAAE;QACT;;;;WAIG;QACH,IAAI,EAAE,MAAM,CAAA;KACb,CAAA;CACF;AAED,eAAO,MAAM,eAAe,mFAMzB,kBAAkB,KAAG,OAuEA,CAAA"}
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import { hostname } from 'node:os';
|
|
2
|
+
import * as WT from 'node:worker_threads';
|
|
3
|
+
import { Devtools, UnexpectedError } from '@livestore/common';
|
|
4
|
+
import { makeNodeDevtoolsChannel } from '@livestore/devtools-node-common/web-channel';
|
|
5
|
+
import { loadSqlite3Wasm } from '@livestore/sqlite-wasm/load-wasm';
|
|
6
|
+
import { sqliteDbFactory } from '@livestore/sqlite-wasm/node';
|
|
7
|
+
import { BucketQueue, Effect, Fiber, ParseResult, Schema, Stream, SubscriptionRef, Worker, WorkerError, } from '@livestore/utils/effect';
|
|
8
|
+
import { PlatformNode } from '@livestore/utils/node';
|
|
9
|
+
import * as WorkerSchema from '../worker-schema.js';
|
|
10
|
+
export const makeNodeAdapter = ({ workerUrl, schemaPath, baseDirectory, devtools: devtoolsOptions = { port: 4242 }, clientId = hostname(), }) => (({ storeId, devtoolsEnabled, shutdown, connectDevtoolsToStore }) => Effect.gen(function* () {
|
|
11
|
+
// TODO make this dynamic and actually support multiple sessions
|
|
12
|
+
const sessionId = 'static';
|
|
13
|
+
const sqlite3 = yield* Effect.promise(() => loadSqlite3Wasm());
|
|
14
|
+
const makeSqliteDb = yield* sqliteDbFactory({ sqlite3 });
|
|
15
|
+
// TODO consider bringing back happy-path initialisation boost
|
|
16
|
+
// const fileData = yield* fs.readFile(dbFilePath).pipe(Effect.either)
|
|
17
|
+
// if (fileData._tag === 'Right') {
|
|
18
|
+
// syncInMemoryDb.import(fileData.right)
|
|
19
|
+
// } else {
|
|
20
|
+
// yield* Effect.logWarning('Failed to load database file', fileData.left)
|
|
21
|
+
// }
|
|
22
|
+
const syncInMemoryDb = yield* makeSqliteDb({ _tag: 'in-memory' }).pipe(Effect.orDie);
|
|
23
|
+
// TODO actually implement this multi-session support
|
|
24
|
+
const lockStatus = yield* SubscriptionRef.make('has-lock');
|
|
25
|
+
const { leaderThread, initialSnapshot } = yield* makeLeaderThread({
|
|
26
|
+
shutdown,
|
|
27
|
+
storeId,
|
|
28
|
+
clientId,
|
|
29
|
+
sessionId,
|
|
30
|
+
workerUrl,
|
|
31
|
+
baseDirectory,
|
|
32
|
+
devtoolsEnabled,
|
|
33
|
+
devtoolsOptions,
|
|
34
|
+
schemaPath,
|
|
35
|
+
});
|
|
36
|
+
syncInMemoryDb.import(initialSnapshot);
|
|
37
|
+
if (devtoolsEnabled) {
|
|
38
|
+
yield* Effect.gen(function* () {
|
|
39
|
+
const storeDevtoolsChannel = yield* makeNodeDevtoolsChannel({
|
|
40
|
+
nodeName: `client-session-${storeId}-${clientId}-${sessionId}`,
|
|
41
|
+
target: `devtools`,
|
|
42
|
+
url: `ws://localhost:${devtoolsOptions.port}`,
|
|
43
|
+
schema: {
|
|
44
|
+
listen: Devtools.ClientSession.MessageToApp,
|
|
45
|
+
send: Devtools.ClientSession.MessageFromApp,
|
|
46
|
+
},
|
|
47
|
+
});
|
|
48
|
+
yield* connectDevtoolsToStore(storeDevtoolsChannel);
|
|
49
|
+
}).pipe(Effect.tapCauseLogPretty, Effect.forkScoped);
|
|
50
|
+
}
|
|
51
|
+
const devtools = devtoolsEnabled
|
|
52
|
+
? { enabled: true, pullLatch: yield* Effect.makeLatch(true), pushLatch: yield* Effect.makeLatch(true) }
|
|
53
|
+
: { enabled: false };
|
|
54
|
+
const clientSession = {
|
|
55
|
+
sqliteDb: syncInMemoryDb,
|
|
56
|
+
leaderThread,
|
|
57
|
+
devtools,
|
|
58
|
+
lockStatus,
|
|
59
|
+
clientId,
|
|
60
|
+
sessionId,
|
|
61
|
+
shutdown,
|
|
62
|
+
};
|
|
63
|
+
return clientSession;
|
|
64
|
+
}).pipe(Effect.withSpan('@livestore/adapter-node:adapter'), Effect.parallelFinalizers, Effect.provide(PlatformNode.NodeFileSystem.layer)));
|
|
65
|
+
const makeLeaderThread = ({ shutdown, storeId, clientId, sessionId, workerUrl, baseDirectory, devtoolsEnabled, devtoolsOptions, schemaPath, }) => Effect.gen(function* () {
|
|
66
|
+
const nodeWorker = new WT.Worker(workerUrl, {
|
|
67
|
+
execArgv: process.env.DEBUG_WORKER ? ['--inspect --enable-source-maps'] : ['--enable-source-maps'],
|
|
68
|
+
argv: [Schema.encodeSync(WorkerSchema.WorkerArgv)({ storeId, clientId, sessionId })],
|
|
69
|
+
});
|
|
70
|
+
const leaderThreadFiber = yield* Worker.makePoolSerialized({
|
|
71
|
+
size: 1,
|
|
72
|
+
concurrency: 100,
|
|
73
|
+
initialMessage: () => new WorkerSchema.LeaderWorkerInner.InitialMessage({
|
|
74
|
+
storeId,
|
|
75
|
+
clientId,
|
|
76
|
+
baseDirectory,
|
|
77
|
+
devtools: { enabled: devtoolsEnabled, port: devtoolsOptions.port },
|
|
78
|
+
schemaPath,
|
|
79
|
+
}),
|
|
80
|
+
}).pipe(Effect.provide(PlatformNode.NodeWorker.layer(() => nodeWorker)), UnexpectedError.mapToUnexpectedError, Effect.tapErrorCause(shutdown), Effect.withSpan('@livestore/adapter-node:adapter:setupLeaderThread'), Effect.tapCauseLogPretty, Effect.forkScoped);
|
|
81
|
+
yield* Effect.addFinalizer(() => Effect.gen(function* () {
|
|
82
|
+
// We first try to gracefully shutdown the leader worker and then forcefully terminate it
|
|
83
|
+
yield* Effect.raceFirst(runInWorker(new WorkerSchema.LeaderWorkerInner.Shutdown()).pipe(Effect.andThen(() => nodeWorker.terminate())), Effect.sync(() => {
|
|
84
|
+
console.warn('[@livestore/adapter-node:adapter] Worker did not gracefully shutdown in time, terminating it');
|
|
85
|
+
nodeWorker.terminate();
|
|
86
|
+
}).pipe(Effect.delay(1000))).pipe(Effect.exit); // The disconnect is to prevent the interrupt to bubble out
|
|
87
|
+
}).pipe(Effect.withSpan('@livestore/adapter-node:adapter:shutdown'), Effect.tapCauseLogPretty, Effect.orDie));
|
|
88
|
+
const runInWorker = (req) => Fiber.join(leaderThreadFiber).pipe(Effect.flatMap((worker) => worker.executeEffect(req)), Effect.logWarnIfTakesLongerThan({
|
|
89
|
+
label: `@livestore/adapter-node:client-session:runInWorker:${req._tag}`,
|
|
90
|
+
duration: 2000,
|
|
91
|
+
}), Effect.withSpan(`@livestore/adapter-node:client-session:runInWorker:${req._tag}`), Effect.mapError((cause) => Schema.is(UnexpectedError)(cause)
|
|
92
|
+
? cause
|
|
93
|
+
: ParseResult.isParseError(cause) || Schema.is(WorkerError.WorkerError)(cause)
|
|
94
|
+
? new UnexpectedError({ cause })
|
|
95
|
+
: cause), Effect.catchAllDefect((cause) => new UnexpectedError({ cause })));
|
|
96
|
+
const runInWorkerStream = (req) => Effect.gen(function* () {
|
|
97
|
+
const sharedWorker = yield* Fiber.join(leaderThreadFiber);
|
|
98
|
+
return sharedWorker.execute(req).pipe(Stream.mapError((cause) => Schema.is(UnexpectedError)(cause)
|
|
99
|
+
? cause
|
|
100
|
+
: ParseResult.isParseError(cause) || Schema.is(WorkerError.WorkerError)(cause)
|
|
101
|
+
? new UnexpectedError({ cause })
|
|
102
|
+
: cause), Stream.withSpan(`@livestore/adapter-node:client-session:runInWorkerStream:${req._tag}`));
|
|
103
|
+
}).pipe(Stream.unwrap);
|
|
104
|
+
const initialLeaderHead = yield* runInWorker(new WorkerSchema.LeaderWorkerInner.GetLeaderHead());
|
|
105
|
+
const networkStatus = yield* SubscriptionRef.make({
|
|
106
|
+
isConnected: true,
|
|
107
|
+
timestampMs: Date.now(),
|
|
108
|
+
latchClosed: false,
|
|
109
|
+
});
|
|
110
|
+
const pushQueue = yield* BucketQueue.make();
|
|
111
|
+
yield* Effect.gen(function* () {
|
|
112
|
+
const batch = yield* BucketQueue.takeBetween(pushQueue, 1, 100);
|
|
113
|
+
yield* runInWorker(new WorkerSchema.LeaderWorkerInner.PushToLeader({ batch })).pipe(Effect.withSpan('@livestore/adapter-node:client-session:pushToLeader', {
|
|
114
|
+
attributes: { batchSize: batch.length },
|
|
115
|
+
}),
|
|
116
|
+
// We can ignore the error here because the ClientSessionSyncProcessor will retry after rebasing
|
|
117
|
+
Effect.ignoreLogged);
|
|
118
|
+
}).pipe(Effect.forever, Effect.interruptible, Effect.tapCauseLogPretty, Effect.forkScoped);
|
|
119
|
+
const bootResult = yield* runInWorker(new WorkerSchema.LeaderWorkerInner.GetRecreateSnapshot()).pipe(Effect.timeout(10_000), UnexpectedError.mapToUnexpectedError, Effect.withSpan('@livestore/adapter-node:client-session:export'));
|
|
120
|
+
const leaderThread = {
|
|
121
|
+
networkStatus,
|
|
122
|
+
mutations: {
|
|
123
|
+
pull: runInWorkerStream(new WorkerSchema.LeaderWorkerInner.PullStream({ cursor: initialLeaderHead })).pipe(Stream.orDie),
|
|
124
|
+
// NOTE instead of sending the worker message right away, we're batching the events in order to
|
|
125
|
+
// - maintain a consistent order of events
|
|
126
|
+
// - improve efficiency by reducing the number of messages
|
|
127
|
+
push: (batch) => BucketQueue.offerAll(pushQueue, batch),
|
|
128
|
+
},
|
|
129
|
+
initialState: {
|
|
130
|
+
leaderHead: initialLeaderHead,
|
|
131
|
+
migrationsReport: bootResult.migrationsReport,
|
|
132
|
+
},
|
|
133
|
+
export: runInWorker(new WorkerSchema.LeaderWorkerInner.Export()).pipe(Effect.timeout(10_000), UnexpectedError.mapToUnexpectedError, Effect.withSpan('@livestore/adapter-node:client-session:export')),
|
|
134
|
+
getMutationLogData: Effect.dieMessage('Not implemented'),
|
|
135
|
+
getSyncState: runInWorker(new WorkerSchema.LeaderWorkerInner.GetLeaderSyncState()).pipe(UnexpectedError.mapToUnexpectedError, Effect.withSpan('@livestore/adapter-node:client-session:getLeaderSyncState')),
|
|
136
|
+
sendDevtoolsMessage: (message) => runInWorker(new WorkerSchema.LeaderWorkerInner.ExtraDevtoolsMessage({ message })).pipe(UnexpectedError.mapToUnexpectedError, Effect.withSpan('@livestore/adapter-node:client-session:devtoolsMessageForLeader')),
|
|
137
|
+
};
|
|
138
|
+
return { leaderThread, initialSnapshot: bootResult.snapshot };
|
|
139
|
+
});
|
|
140
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/client-session/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { UnexpectedError } from '@livestore/common';
|
|
2
|
+
import type { Scope } from '@livestore/utils/effect';
|
|
3
|
+
import { Effect } from '@livestore/utils/effect';
|
|
4
|
+
/**
|
|
5
|
+
* Starts a devtools HTTP/WS server which serves ...
|
|
6
|
+
* - the Devtools UI via Vite
|
|
7
|
+
* - the Devtools Protocol via WebSocket Webmesh
|
|
8
|
+
*/
|
|
9
|
+
export declare const startDevtoolsServer: ({ schemaPath, storeId, clientId, sessionId, port, }: {
|
|
10
|
+
schemaPath: string;
|
|
11
|
+
storeId: string;
|
|
12
|
+
clientId: string;
|
|
13
|
+
sessionId: string;
|
|
14
|
+
port: number;
|
|
15
|
+
}) => Effect.Effect<void, UnexpectedError, Scope.Scope>;
|
|
16
|
+
//# sourceMappingURL=devtools-server.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"devtools-server.d.ts","sourceRoot":"","sources":["../../src/devtools/devtools-server.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAA;AACpD,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAKhD;;;;GAIG;AACH,eAAO,MAAM,mBAAmB,wDAM7B;IACD,UAAU,EAAE,MAAM,CAAA;IAClB,OAAO,EAAE,MAAM,CAAA;IACf,QAAQ,EAAE,MAAM,CAAA;IAChB,SAAS,EAAE,MAAM,CAAA;IACjB,IAAI,EAAE,MAAM,CAAA;CACb,KAAG,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,eAAe,EAAE,KAAK,CAAC,KAAK,CA4D8B,CAAA"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import http from 'node:http';
|
|
2
|
+
import path from 'node:path';
|
|
3
|
+
import { UnexpectedError } from '@livestore/common';
|
|
4
|
+
import { Effect } from '@livestore/utils/effect';
|
|
5
|
+
import { makeWebSocketServer } from '@livestore/webmesh/websocket-server';
|
|
6
|
+
import { makeViteServer } from './vite-dev-server.js';
|
|
7
|
+
/**
|
|
8
|
+
* Starts a devtools HTTP/WS server which serves ...
|
|
9
|
+
* - the Devtools UI via Vite
|
|
10
|
+
* - the Devtools Protocol via WebSocket Webmesh
|
|
11
|
+
*/
|
|
12
|
+
export const startDevtoolsServer = ({ schemaPath, storeId, clientId, sessionId, port, }) => Effect.gen(function* () {
|
|
13
|
+
const httpServer = http.createServer();
|
|
14
|
+
const webSocketServer = yield* makeWebSocketServer({ relayNodeName: 'ws' });
|
|
15
|
+
yield* Effect.addFinalizer(() => Effect.sync(() => httpServer.close()));
|
|
16
|
+
// Handle upgrade manually
|
|
17
|
+
httpServer.on('upgrade', (request, socket, head) => {
|
|
18
|
+
webSocketServer.handleUpgrade(request, socket, head, (ws) => {
|
|
19
|
+
webSocketServer.emit('connection', ws, request);
|
|
20
|
+
});
|
|
21
|
+
});
|
|
22
|
+
const startServer = (port) => Effect.async((cb) => {
|
|
23
|
+
httpServer.on('error', (err) => {
|
|
24
|
+
cb(UnexpectedError.make({ cause: err }));
|
|
25
|
+
});
|
|
26
|
+
httpServer.listen(port, () => {
|
|
27
|
+
cb(Effect.succeed(undefined));
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
yield* startServer(port);
|
|
31
|
+
yield* Effect.logDebug(`[@livestore/adapter-node:devtools] LiveStore devtools are available at http://localhost:${port}/livestore-devtools`);
|
|
32
|
+
const viteServer = yield* makeViteServer({
|
|
33
|
+
mode: { _tag: 'node', storeId, clientId, sessionId, url: `ws://localhost:${port}` },
|
|
34
|
+
schemaPath: path.resolve(process.cwd(), schemaPath),
|
|
35
|
+
viteConfig: (viteConfig) => {
|
|
36
|
+
viteConfig.server ??= {};
|
|
37
|
+
viteConfig.server.fs ??= {};
|
|
38
|
+
// TODO move this into the example code
|
|
39
|
+
// Point to Overtone monorepo root
|
|
40
|
+
viteConfig.server.fs.allow ??= [];
|
|
41
|
+
viteConfig.server.fs.allow.push(process.env.WORKSPACE_ROOT + '/../..');
|
|
42
|
+
viteConfig.optimizeDeps ??= {};
|
|
43
|
+
viteConfig.optimizeDeps.force = true;
|
|
44
|
+
return viteConfig;
|
|
45
|
+
},
|
|
46
|
+
});
|
|
47
|
+
yield* Effect.addFinalizer(() => Effect.promise(() => viteServer.close()));
|
|
48
|
+
httpServer.on('request', (req, res) => {
|
|
49
|
+
if (req.url === '/' || req.url === '') {
|
|
50
|
+
res.writeHead(302, { Location: '/livestore-devtools' });
|
|
51
|
+
res.end();
|
|
52
|
+
}
|
|
53
|
+
else if (req.url?.startsWith('/livestore-devtools')) {
|
|
54
|
+
return viteServer.middlewares(req, res);
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
}).pipe(Effect.withSpan('@livestore/adapter-node:devtools:startDevtoolsServer'));
|
|
58
|
+
//# sourceMappingURL=devtools-server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"devtools-server.js","sourceRoot":"","sources":["../../src/devtools/devtools-server.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mod.d.ts","sourceRoot":"","sources":["../../src/devtools/mod.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA;AACrD,YAAY,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mod.js","sourceRoot":"","sources":["../../src/devtools/mod.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { UnexpectedError } from '@livestore/common';
|
|
2
|
+
import { Effect } from '@livestore/utils/effect';
|
|
3
|
+
import * as Vite from 'vite';
|
|
4
|
+
import type { Options } from './types.js';
|
|
5
|
+
export declare const makeViteServer: (options: Options) => Effect.Effect<Vite.ViteDevServer, UnexpectedError>;
|
|
6
|
+
export declare const getFreePort: Effect.Effect<number, UnexpectedError, never>;
|
|
7
|
+
//# sourceMappingURL=vite-dev-server.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vite-dev-server.d.ts","sourceRoot":"","sources":["../../src/devtools/vite-dev-server.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAChD,OAAO,KAAK,IAAI,MAAM,MAAM,CAAA;AAE5B,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AAIzC,eAAO,MAAM,cAAc,YAAa,OAAO,KAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,eAAe,CAyCtB,CAAA;AAiD7E,eAAO,MAAM,WAAW,+CAmBtB,CAAA"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import * as http from 'node:http';
|
|
2
|
+
import path from 'node:path';
|
|
3
|
+
import { fileURLToPath } from 'node:url';
|
|
4
|
+
import { UnexpectedError } from '@livestore/common';
|
|
5
|
+
import { Effect } from '@livestore/utils/effect';
|
|
6
|
+
import * as Vite from 'vite';
|
|
7
|
+
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
|
8
|
+
export const makeViteServer = (options) => Effect.gen(function* () {
|
|
9
|
+
const hmrPort = yield* getFreePort;
|
|
10
|
+
const cwd = process.cwd();
|
|
11
|
+
const defaultViteConfig = Vite.defineConfig({
|
|
12
|
+
server: {
|
|
13
|
+
middlewareMode: true,
|
|
14
|
+
hmr: {
|
|
15
|
+
port: hmrPort,
|
|
16
|
+
},
|
|
17
|
+
fs: {
|
|
18
|
+
// Adds `node_modules` so we can import `@livestore/wa-sqlite` for WASM to work
|
|
19
|
+
allow: [path.resolve(__dirname, '..', '..')],
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
resolve: {
|
|
23
|
+
alias: {
|
|
24
|
+
'@schema': path.resolve(cwd, options.schemaPath),
|
|
25
|
+
},
|
|
26
|
+
},
|
|
27
|
+
appType: 'spa',
|
|
28
|
+
optimizeDeps: {
|
|
29
|
+
// TODO remove once fixed https://github.com/vitejs/vite/issues/8427
|
|
30
|
+
exclude: ['@livestore/wa-sqlite'],
|
|
31
|
+
},
|
|
32
|
+
root: __dirname,
|
|
33
|
+
base: '/livestore-devtools/',
|
|
34
|
+
plugins: [virtualHtmlPlugin(options.mode)],
|
|
35
|
+
clearScreen: false,
|
|
36
|
+
logLevel: 'silent',
|
|
37
|
+
});
|
|
38
|
+
const viteConfig = options.viteConfig?.(defaultViteConfig) ?? defaultViteConfig;
|
|
39
|
+
const viteServer = yield* Effect.promise(() => Vite.createServer(viteConfig)).pipe(UnexpectedError.mapToUnexpectedError);
|
|
40
|
+
return viteServer;
|
|
41
|
+
}).pipe(Effect.withSpan('@livestore/adapter-node:devtools:makeViteServer'));
|
|
42
|
+
// TODO unify this with `@livestore/devtools-vite/plugin.ts`
|
|
43
|
+
const virtualHtmlPlugin = (mode) => ({
|
|
44
|
+
name: 'virtual-html',
|
|
45
|
+
configureServer: (server) => {
|
|
46
|
+
return () => {
|
|
47
|
+
server.middlewares.use(async (req, res, next) => {
|
|
48
|
+
if (req.url === '/' || req.url === '' || req.url === '/index.html') {
|
|
49
|
+
const html = `
|
|
50
|
+
<!doctype html>
|
|
51
|
+
<html lang="en">
|
|
52
|
+
<head>
|
|
53
|
+
<meta charset="UTF-8" />
|
|
54
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
55
|
+
<meta name="livestore-devtools" content="true" />
|
|
56
|
+
<title>LiveStore Devtools</title>
|
|
57
|
+
</head>
|
|
58
|
+
<body>
|
|
59
|
+
<div id="root"></div>
|
|
60
|
+
<script type="module">
|
|
61
|
+
import '@livestore/devtools-react/index.css'
|
|
62
|
+
import { mountDevtools } from '@livestore/devtools-react'
|
|
63
|
+
import sharedWorker from '@livestore/adapter-web/shared-worker?sharedworker'
|
|
64
|
+
import { schema } from '@schema'
|
|
65
|
+
|
|
66
|
+
mountDevtools({
|
|
67
|
+
schema,
|
|
68
|
+
rootEl: document.getElementById('root'),
|
|
69
|
+
sharedWorker,
|
|
70
|
+
mode: ${JSON.stringify(mode)},
|
|
71
|
+
license: ${JSON.stringify(process.env.LSD_LICENSE)},
|
|
72
|
+
})
|
|
73
|
+
</script>
|
|
74
|
+
</body>
|
|
75
|
+
</html>
|
|
76
|
+
`;
|
|
77
|
+
const transformedHtml = await server.transformIndexHtml(req.url, html);
|
|
78
|
+
res.statusCode = 200;
|
|
79
|
+
res.setHeader('Content-Type', 'text/html');
|
|
80
|
+
res.end(transformedHtml);
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
next();
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
};
|
|
87
|
+
},
|
|
88
|
+
});
|
|
89
|
+
export const getFreePort = Effect.async((cb) => {
|
|
90
|
+
const server = http.createServer();
|
|
91
|
+
// Listen on port 0 to get an available port
|
|
92
|
+
server.listen(0, () => {
|
|
93
|
+
const address = server.address();
|
|
94
|
+
if (address && typeof address === 'object') {
|
|
95
|
+
const port = address.port;
|
|
96
|
+
server.close(() => cb(Effect.succeed(port)));
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
server.close(() => cb(UnexpectedError.make({ cause: 'Failed to get a free port' })));
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
// Error handling in case the server encounters an error
|
|
103
|
+
server.on('error', (err) => {
|
|
104
|
+
server.close(() => cb(UnexpectedError.make({ cause: err })));
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
//# sourceMappingURL=vite-dev-server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vite-dev-server.js","sourceRoot":"","sources":["../../src/devtools/vite-dev-server.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Adapter, SyncOptions } from '@livestore/common';
|
|
2
|
+
export interface InMemoryAdapterOptions {
|
|
3
|
+
sync?: SyncOptions;
|
|
4
|
+
/**
|
|
5
|
+
* @default 'in-memory'
|
|
6
|
+
*/
|
|
7
|
+
clientId?: string;
|
|
8
|
+
}
|
|
9
|
+
/** NOTE: This adapter is currently only used for testing */
|
|
10
|
+
export declare const makeInMemoryAdapter: ({ sync: syncOptions, clientId }: InMemoryAdapterOptions) => Adapter;
|
|
11
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/in-memory/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,OAAO,EAKP,WAAW,EACZ,MAAM,mBAAmB,CAAA;AAY1B,MAAM,WAAW,sBAAsB;IACrC,IAAI,CAAC,EAAE,WAAW,CAAA;IAClB;;OAEG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB;AAED,4DAA4D;AAC5D,eAAO,MAAM,mBAAmB,oCACkB,sBAAsB,KAAG,OAqC1B,CAAA"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { UnexpectedError } from '@livestore/common';
|
|
2
|
+
import { getClientHeadFromDb, LeaderThreadCtx, makeLeaderThreadLayer } from '@livestore/common/leader-thread';
|
|
3
|
+
import { MutationEvent } from '@livestore/common/schema';
|
|
4
|
+
import { sqliteDbFactory } from '@livestore/sqlite-wasm/browser';
|
|
5
|
+
import { loadSqlite3Wasm } from '@livestore/sqlite-wasm/load-wasm';
|
|
6
|
+
import { Effect, FetchHttpClient, Layer, Stream, SubscriptionRef, WebChannel } from '@livestore/utils/effect';
|
|
7
|
+
import { nanoid } from '@livestore/utils/nanoid';
|
|
8
|
+
/** NOTE: This adapter is currently only used for testing */
|
|
9
|
+
export const makeInMemoryAdapter = ({ sync: syncOptions, clientId = 'in-memory' }) => ({ schema, storeId,
|
|
10
|
+
// devtoolsEnabled, bootStatusQueue, shutdown, connectDevtoolsToStore
|
|
11
|
+
}) => Effect.gen(function* () {
|
|
12
|
+
const sqlite3 = yield* Effect.promise(() => loadSqlite3Wasm());
|
|
13
|
+
const makeSqliteDb = sqliteDbFactory({ sqlite3 });
|
|
14
|
+
const sqliteDb = yield* makeSqliteDb({ _tag: 'in-memory' });
|
|
15
|
+
const lockStatus = SubscriptionRef.make('has-lock').pipe(Effect.runSync);
|
|
16
|
+
const sessionId = nanoid(6);
|
|
17
|
+
const { leaderThread, initialSnapshot } = yield* makeLeaderThread({
|
|
18
|
+
storeId,
|
|
19
|
+
clientId,
|
|
20
|
+
schema,
|
|
21
|
+
makeSqliteDb,
|
|
22
|
+
syncOptions,
|
|
23
|
+
});
|
|
24
|
+
sqliteDb.import(initialSnapshot);
|
|
25
|
+
const clientSession = {
|
|
26
|
+
sqliteDb,
|
|
27
|
+
devtools: { enabled: false },
|
|
28
|
+
clientId,
|
|
29
|
+
sessionId,
|
|
30
|
+
lockStatus,
|
|
31
|
+
leaderThread,
|
|
32
|
+
shutdown: () => Effect.dieMessage('TODO implement shutdown'),
|
|
33
|
+
};
|
|
34
|
+
return clientSession;
|
|
35
|
+
}).pipe(UnexpectedError.mapToUnexpectedError);
|
|
36
|
+
const makeLeaderThread = ({ storeId, clientId, schema, makeSqliteDb, syncOptions, }) => Effect.gen(function* () {
|
|
37
|
+
const layer = yield* Layer.memoize(makeLeaderThreadLayer({
|
|
38
|
+
clientId,
|
|
39
|
+
dbReadModel: yield* makeSqliteDb({ _tag: 'in-memory' }),
|
|
40
|
+
dbMutationLog: yield* makeSqliteDb({ _tag: 'in-memory' }),
|
|
41
|
+
devtoolsOptions: { enabled: false },
|
|
42
|
+
makeSqliteDb,
|
|
43
|
+
schema,
|
|
44
|
+
shutdownChannel: yield* WebChannel.noopChannel(),
|
|
45
|
+
storeId,
|
|
46
|
+
syncOptions,
|
|
47
|
+
}).pipe(Layer.provideMerge(FetchHttpClient.layer)));
|
|
48
|
+
return yield* Effect.gen(function* () {
|
|
49
|
+
const { dbReadModel: db, dbMutationLog, syncProcessor, connectedClientSessionPullQueues, extraIncomingMessagesQueue, initialState, } = yield* LeaderThreadCtx;
|
|
50
|
+
const initialLeaderHead = getClientHeadFromDb(dbMutationLog);
|
|
51
|
+
const pullQueue = yield* connectedClientSessionPullQueues.makeQueue(initialLeaderHead);
|
|
52
|
+
const leaderThread = {
|
|
53
|
+
mutations: {
|
|
54
|
+
pull: Stream.fromQueue(pullQueue),
|
|
55
|
+
push: (batch) => syncProcessor
|
|
56
|
+
.push(batch.map((item) => new MutationEvent.EncodedWithMeta(item)))
|
|
57
|
+
.pipe(Effect.provide(layer), Effect.scoped),
|
|
58
|
+
},
|
|
59
|
+
initialState: { leaderHead: initialLeaderHead, migrationsReport: initialState.migrationsReport },
|
|
60
|
+
export: Effect.sync(() => db.export()),
|
|
61
|
+
getMutationLogData: Effect.sync(() => dbMutationLog.export()),
|
|
62
|
+
// TODO
|
|
63
|
+
networkStatus: SubscriptionRef.make({ isConnected: false, timestampMs: Date.now(), latchClosed: false }).pipe(Effect.runSync),
|
|
64
|
+
getSyncState: syncProcessor.syncState,
|
|
65
|
+
sendDevtoolsMessage: (message) => extraIncomingMessagesQueue.offer(message),
|
|
66
|
+
};
|
|
67
|
+
const initialSnapshot = db.export();
|
|
68
|
+
return { leaderThread, initialSnapshot };
|
|
69
|
+
}).pipe(Effect.provide(layer));
|
|
70
|
+
});
|
|
71
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/in-memory/index.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAA;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAA;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"leader-thread-lazy.d.ts","sourceRoot":"","sources":["../src/leader-thread-lazy.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
const run = async () => {
|
|
2
|
+
const start = Date.now();
|
|
3
|
+
// @ts-expect-error todo
|
|
4
|
+
const _module = await import('./leader-thread.bundle.js');
|
|
5
|
+
const end = Date.now();
|
|
6
|
+
console.log(`[@livestore/adapter-node:leader] Loaded in ${end - start}ms`);
|
|
7
|
+
};
|
|
8
|
+
run();
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=leader-thread-lazy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"leader-thread-lazy.js","sourceRoot":"","sources":["../src/leader-thread-lazy.ts"],"names":[],"mappings":"AAAA,MAAM,GAAG,GAAG,KAAK,IAAI,EAAE;IACrB,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;IACxB,wBAAwB;IACxB,MAAM,OAAO,GAAG,MAAM,MAAM,CAAC,2BAA2B,CAAC,CAAA;IACzD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;IACtB,OAAO,CAAC,GAAG,CAAC,8CAA8C,GAAG,GAAG,KAAK,IAAI,CAAC,CAAA;AAC5E,CAAC,CAAA;AAED,GAAG,EAAE,CAAA"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import './thread-polyfill.js';
|
|
2
|
+
import type { SyncOptions } from '@livestore/common';
|
|
3
|
+
import { Effect } from '@livestore/utils/effect';
|
|
4
|
+
import type * as otel from '@opentelemetry/api';
|
|
5
|
+
export type WorkerOptions = {
|
|
6
|
+
sync?: SyncOptions;
|
|
7
|
+
otelOptions?: {
|
|
8
|
+
tracer?: otel.Tracer;
|
|
9
|
+
/** @default 'livestore-node-leader-thread' */
|
|
10
|
+
serviceName?: string;
|
|
11
|
+
};
|
|
12
|
+
};
|
|
13
|
+
export declare const getWorkerArgs: () => {
|
|
14
|
+
readonly clientId: string;
|
|
15
|
+
readonly storeId: string;
|
|
16
|
+
readonly sessionId: string;
|
|
17
|
+
};
|
|
18
|
+
export declare const makeWorker: (options: WorkerOptions) => void;
|
|
19
|
+
export declare const makeWorkerEffect: (options: WorkerOptions) => Effect.Effect<never, import("@effect/platform/WorkerError").WorkerError, never>;
|
|
20
|
+
//# sourceMappingURL=make-leader-worker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"make-leader-worker.d.ts","sourceRoot":"","sources":["../src/make-leader-worker.ts"],"names":[],"mappings":"AAAA,OAAO,sBAAsB,CAAA;AAU7B,OAAO,KAAK,EAAiB,WAAW,EAAE,MAAM,mBAAmB,CAAA;AAenE,OAAO,EACL,MAAM,EAUP,MAAM,yBAAyB,CAAA;AAEhC,OAAO,KAAK,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAM/C,MAAM,MAAM,aAAa,GAAG;IAC1B,IAAI,CAAC,EAAE,WAAW,CAAA;IAClB,WAAW,CAAC,EAAE;QACZ,MAAM,CAAC,EAAE,IAAI,CAAC,MAAM,CAAA;QACpB,8CAA8C;QAC9C,WAAW,CAAC,EAAE,MAAM,CAAA;KACrB,CAAA;CACF,CAAA;AAED,eAAO,MAAM,aAAa;;;;CAAqE,CAAA;AAE/F,eAAO,MAAM,UAAU,YAAa,aAAa,SAEhD,CAAA;AAED,eAAO,MAAM,gBAAgB,YAAa,aAAa,oFAsGtD,CAAA"}
|