@livestore/adapter-node 0.4.0-dev.22 → 0.4.0-dev.23
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 -1
- package/dist/client-session/adapter.d.ts +1 -0
- package/dist/client-session/adapter.d.ts.map +1 -1
- package/dist/client-session/adapter.js +15 -23
- package/dist/client-session/adapter.js.map +1 -1
- package/dist/devtools/devtools-server.d.ts.map +1 -1
- package/dist/devtools/devtools-server.js +6 -6
- package/dist/devtools/devtools-server.js.map +1 -1
- package/dist/devtools/mod.d.ts +1 -1
- package/dist/devtools/mod.d.ts.map +1 -1
- package/dist/devtools/mod.js +1 -1
- package/dist/devtools/mod.js.map +1 -1
- package/dist/devtools/vite-dev-server.d.ts +25 -3
- package/dist/devtools/vite-dev-server.d.ts.map +1 -1
- package/dist/devtools/vite-dev-server.js +40 -5
- package/dist/devtools/vite-dev-server.js.map +1 -1
- package/dist/leader-thread-shared.js +2 -2
- package/dist/leader-thread-shared.js.map +1 -1
- package/dist/make-leader-worker.d.ts +1 -1
- package/dist/make-leader-worker.d.ts.map +1 -1
- package/dist/make-leader-worker.js +15 -17
- package/dist/make-leader-worker.js.map +1 -1
- package/dist/shutdown-channel.d.ts.map +1 -1
- package/dist/shutdown-channel.js.map +1 -1
- package/dist/worker-schema.d.ts +24 -24
- package/dist/worker-schema.d.ts.map +1 -1
- package/dist/worker-schema.js +16 -16
- package/dist/worker-schema.js.map +1 -1
- package/package.json +59 -19
- package/src/client-session/adapter.ts +26 -46
- package/src/devtools/devtools-server.ts +12 -10
- package/src/devtools/mod.ts +1 -1
- package/src/devtools/vite-dev-server.ts +60 -6
- package/src/leader-thread-shared.ts +4 -4
- package/src/make-leader-worker.ts +38 -47
- package/src/shutdown-channel.ts +1 -0
- package/src/worker-schema.ts +16 -16
package/dist/worker-schema.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Devtools,
|
|
1
|
+
import { Devtools, SyncState, UnknownError } from '@livestore/common';
|
|
2
2
|
import { EventSequenceNumber } from '@livestore/common/schema';
|
|
3
3
|
import { Schema } from '@livestore/utils/effect';
|
|
4
4
|
export declare const WorkerArgv: Schema.transform<Schema.SchemaClass<unknown, string, never>, Schema.Struct<{
|
|
@@ -50,7 +50,7 @@ declare const LeaderWorkerOuterInitialMessage_base: Schema.TaggedRequestClass<Le
|
|
|
50
50
|
readonly _tag: Schema.tag<"InitialMessage">;
|
|
51
51
|
} & {
|
|
52
52
|
port: Schema.Schema<MessagePort, MessagePort, never>;
|
|
53
|
-
}, typeof Schema.Void, typeof
|
|
53
|
+
}, typeof Schema.Void, typeof Schema.Never>;
|
|
54
54
|
export declare class LeaderWorkerOuterInitialMessage extends LeaderWorkerOuterInitialMessage_base {
|
|
55
55
|
}
|
|
56
56
|
declare const LeaderWorkerOuterRequest_base: typeof LeaderWorkerOuterInitialMessage;
|
|
@@ -119,7 +119,7 @@ declare const LeaderWorkerInnerBootStatusStream_base: Schema.TaggedRequestClass<
|
|
|
119
119
|
stage: Schema.Literal<["warning"]>;
|
|
120
120
|
reason: Schema.Literal<["private-browsing", "storage-unavailable", "unknown"]>;
|
|
121
121
|
message: typeof Schema.String;
|
|
122
|
-
}>]>, typeof
|
|
122
|
+
}>]>, typeof Schema.Never>;
|
|
123
123
|
export declare class LeaderWorkerInnerBootStatusStream extends LeaderWorkerInnerBootStatusStream_base {
|
|
124
124
|
}
|
|
125
125
|
declare const LeaderWorkerInnerPullStream_base: Schema.TaggedRequestClass<LeaderWorkerInnerPullStream, "PullStream", {
|
|
@@ -136,7 +136,7 @@ declare const LeaderWorkerInnerPullStream_base: Schema.TaggedRequestClass<Leader
|
|
|
136
136
|
}, never>;
|
|
137
137
|
}, Schema.Struct<{
|
|
138
138
|
payload: typeof SyncState.PayloadUpstream;
|
|
139
|
-
}>, typeof
|
|
139
|
+
}>, typeof Schema.Never>;
|
|
140
140
|
export declare class LeaderWorkerInnerPullStream extends LeaderWorkerInnerPullStream_base {
|
|
141
141
|
}
|
|
142
142
|
declare const LeaderWorkerInnerStreamEvents_base: Schema.TaggedRequestClass<LeaderWorkerInnerStreamEvents, "StreamEvents", {
|
|
@@ -180,7 +180,7 @@ declare const LeaderWorkerInnerStreamEvents_base: Schema.TaggedRequestClass<Lead
|
|
|
180
180
|
};
|
|
181
181
|
clientId: typeof Schema.String;
|
|
182
182
|
sessionId: typeof Schema.String;
|
|
183
|
-
}>, typeof
|
|
183
|
+
}>, typeof Schema.Never>;
|
|
184
184
|
export declare class LeaderWorkerInnerStreamEvents extends LeaderWorkerInnerStreamEvents_base {
|
|
185
185
|
}
|
|
186
186
|
declare const LeaderWorkerInnerPushToLeader_base: Schema.TaggedRequestClass<LeaderWorkerInnerPushToLeader, "PushToLeader", {
|
|
@@ -192,13 +192,13 @@ declare const LeaderWorkerInnerPushToLeader_base: Schema.TaggedRequestClass<Lead
|
|
|
192
192
|
readonly name: string;
|
|
193
193
|
readonly args: any;
|
|
194
194
|
readonly seqNum: {
|
|
195
|
-
readonly global:
|
|
196
|
-
readonly client:
|
|
195
|
+
readonly global: number & import("effect/Brand").Brand<"GlobalEventSequenceNumber">;
|
|
196
|
+
readonly client: number & import("effect/Brand").Brand<"ClientEventSequenceNumber">;
|
|
197
197
|
readonly rebaseGeneration: number;
|
|
198
198
|
};
|
|
199
199
|
readonly parentSeqNum: {
|
|
200
|
-
readonly global:
|
|
201
|
-
readonly client:
|
|
200
|
+
readonly global: number & import("effect/Brand").Brand<"GlobalEventSequenceNumber">;
|
|
201
|
+
readonly client: number & import("effect/Brand").Brand<"ClientEventSequenceNumber">;
|
|
202
202
|
readonly rebaseGeneration: number;
|
|
203
203
|
};
|
|
204
204
|
}, {
|
|
@@ -207,22 +207,22 @@ declare const LeaderWorkerInnerPushToLeader_base: Schema.TaggedRequestClass<Lead
|
|
|
207
207
|
readonly name: string;
|
|
208
208
|
readonly args: any;
|
|
209
209
|
readonly seqNum: {
|
|
210
|
-
readonly global:
|
|
211
|
-
readonly client:
|
|
210
|
+
readonly global: number & import("effect/Brand").Brand<"GlobalEventSequenceNumber">;
|
|
211
|
+
readonly client: number & import("effect/Brand").Brand<"ClientEventSequenceNumber">;
|
|
212
212
|
readonly rebaseGeneration: number;
|
|
213
213
|
};
|
|
214
214
|
readonly parentSeqNum: {
|
|
215
|
-
readonly global:
|
|
216
|
-
readonly client:
|
|
215
|
+
readonly global: number & import("effect/Brand").Brand<"GlobalEventSequenceNumber">;
|
|
216
|
+
readonly client: number & import("effect/Brand").Brand<"ClientEventSequenceNumber">;
|
|
217
217
|
readonly rebaseGeneration: number;
|
|
218
218
|
};
|
|
219
219
|
}, never>>;
|
|
220
|
-
}, Schema.Schema<void, void, never>, Schema.Union<[typeof
|
|
220
|
+
}, Schema.Schema<void, void, never>, Schema.Union<[typeof import("@livestore/common").LeaderAheadError, typeof import("@livestore/common").NonMonotonicBatchError, typeof import("@livestore/common").StaleRebaseGenerationError]>>;
|
|
221
221
|
export declare class LeaderWorkerInnerPushToLeader extends LeaderWorkerInnerPushToLeader_base {
|
|
222
222
|
}
|
|
223
223
|
declare const LeaderWorkerInnerExport_base: Schema.TaggedRequestClass<LeaderWorkerInnerExport, "Export", {
|
|
224
224
|
readonly _tag: Schema.tag<"Export">;
|
|
225
|
-
}, Schema.Schema<Uint8Array<ArrayBuffer>, Uint8Array<ArrayBuffer>, never>, typeof
|
|
225
|
+
}, Schema.Schema<Uint8Array<ArrayBuffer>, Uint8Array<ArrayBuffer>, never>, typeof Schema.Never>;
|
|
226
226
|
export declare class LeaderWorkerInnerExport extends LeaderWorkerInnerExport_base {
|
|
227
227
|
}
|
|
228
228
|
declare const LeaderWorkerInnerGetRecreateSnapshot_base: Schema.TaggedRequestClass<LeaderWorkerInnerGetRecreateSnapshot, "GetRecreateSnapshot", {
|
|
@@ -238,12 +238,12 @@ declare const LeaderWorkerInnerGetRecreateSnapshot_base: Schema.TaggedRequestCla
|
|
|
238
238
|
}>;
|
|
239
239
|
}>>;
|
|
240
240
|
}>;
|
|
241
|
-
}>, typeof
|
|
241
|
+
}>, typeof Schema.Never>;
|
|
242
242
|
export declare class LeaderWorkerInnerGetRecreateSnapshot extends LeaderWorkerInnerGetRecreateSnapshot_base {
|
|
243
243
|
}
|
|
244
244
|
declare const LeaderWorkerInnerExportEventlog_base: Schema.TaggedRequestClass<LeaderWorkerInnerExportEventlog, "ExportEventlog", {
|
|
245
245
|
readonly _tag: Schema.tag<"ExportEventlog">;
|
|
246
|
-
}, Schema.Schema<Uint8Array<ArrayBuffer>, Uint8Array<ArrayBuffer>, never>, typeof
|
|
246
|
+
}, Schema.Schema<Uint8Array<ArrayBuffer>, Uint8Array<ArrayBuffer>, never>, typeof Schema.Never>;
|
|
247
247
|
export declare class LeaderWorkerInnerExportEventlog extends LeaderWorkerInnerExportEventlog_base {
|
|
248
248
|
}
|
|
249
249
|
declare const LeaderWorkerInnerGetLeaderHead_base: Schema.TaggedRequestClass<LeaderWorkerInnerGetLeaderHead, "GetLeaderHead", {
|
|
@@ -256,17 +256,17 @@ declare const LeaderWorkerInnerGetLeaderHead_base: Schema.TaggedRequestClass<Lea
|
|
|
256
256
|
readonly global: number & import("effect/Brand").Brand<"GlobalEventSequenceNumber">;
|
|
257
257
|
readonly client: number & import("effect/Brand").Brand<"ClientEventSequenceNumber">;
|
|
258
258
|
readonly rebaseGeneration: number;
|
|
259
|
-
}, never>, typeof
|
|
259
|
+
}, never>, typeof Schema.Never>;
|
|
260
260
|
export declare class LeaderWorkerInnerGetLeaderHead extends LeaderWorkerInnerGetLeaderHead_base {
|
|
261
261
|
}
|
|
262
262
|
declare const LeaderWorkerInnerGetLeaderSyncState_base: Schema.TaggedRequestClass<LeaderWorkerInnerGetLeaderSyncState, "GetLeaderSyncState", {
|
|
263
263
|
readonly _tag: Schema.tag<"GetLeaderSyncState">;
|
|
264
|
-
}, typeof SyncState.SyncState, typeof
|
|
264
|
+
}, typeof SyncState.SyncState, typeof Schema.Never>;
|
|
265
265
|
export declare class LeaderWorkerInnerGetLeaderSyncState extends LeaderWorkerInnerGetLeaderSyncState_base {
|
|
266
266
|
}
|
|
267
267
|
declare const LeaderWorkerInnerSyncStateStream_base: Schema.TaggedRequestClass<LeaderWorkerInnerSyncStateStream, "SyncStateStream", {
|
|
268
268
|
readonly _tag: Schema.tag<"SyncStateStream">;
|
|
269
|
-
}, typeof SyncState.SyncState, typeof
|
|
269
|
+
}, typeof SyncState.SyncState, typeof Schema.Never>;
|
|
270
270
|
export declare class LeaderWorkerInnerSyncStateStream extends LeaderWorkerInnerSyncStateStream_base {
|
|
271
271
|
}
|
|
272
272
|
declare const LeaderWorkerInnerGetNetworkStatus_base: Schema.TaggedRequestClass<LeaderWorkerInnerGetNetworkStatus, "GetNetworkStatus", {
|
|
@@ -277,7 +277,7 @@ declare const LeaderWorkerInnerGetNetworkStatus_base: Schema.TaggedRequestClass<
|
|
|
277
277
|
devtools: Schema.Struct<{
|
|
278
278
|
latchClosed: typeof Schema.Boolean;
|
|
279
279
|
}>;
|
|
280
|
-
}>, typeof
|
|
280
|
+
}>, typeof Schema.Never>;
|
|
281
281
|
export declare class LeaderWorkerInnerGetNetworkStatus extends LeaderWorkerInnerGetNetworkStatus_base {
|
|
282
282
|
}
|
|
283
283
|
declare const LeaderWorkerInnerNetworkStatusStream_base: Schema.TaggedRequestClass<LeaderWorkerInnerNetworkStatusStream, "NetworkStatusStream", {
|
|
@@ -288,12 +288,12 @@ declare const LeaderWorkerInnerNetworkStatusStream_base: Schema.TaggedRequestCla
|
|
|
288
288
|
devtools: Schema.Struct<{
|
|
289
289
|
latchClosed: typeof Schema.Boolean;
|
|
290
290
|
}>;
|
|
291
|
-
}>, typeof
|
|
291
|
+
}>, typeof Schema.Never>;
|
|
292
292
|
export declare class LeaderWorkerInnerNetworkStatusStream extends LeaderWorkerInnerNetworkStatusStream_base {
|
|
293
293
|
}
|
|
294
294
|
declare const LeaderWorkerInnerShutdown_base: Schema.TaggedRequestClass<LeaderWorkerInnerShutdown, "Shutdown", {
|
|
295
295
|
readonly _tag: Schema.tag<"Shutdown">;
|
|
296
|
-
}, typeof Schema.Void, typeof
|
|
296
|
+
}, typeof Schema.Void, typeof Schema.Never>;
|
|
297
297
|
export declare class LeaderWorkerInnerShutdown extends LeaderWorkerInnerShutdown_base {
|
|
298
298
|
}
|
|
299
299
|
declare const LeaderWorkerInnerExtraDevtoolsMessage_base: Schema.TaggedRequestClass<LeaderWorkerInnerExtraDevtoolsMessage, "ExtraDevtoolsMessage", {
|
|
@@ -319,7 +319,7 @@ declare const LeaderWorkerInnerExtraDevtoolsMessage_base: Schema.TaggedRequestCl
|
|
|
319
319
|
readonly liveStoreVersion: typeof Schema.String;
|
|
320
320
|
readonly clientId: typeof Schema.String;
|
|
321
321
|
}>]>;
|
|
322
|
-
}, typeof Schema.Void, typeof
|
|
322
|
+
}, typeof Schema.Void, typeof Schema.Never>;
|
|
323
323
|
export declare class LeaderWorkerInnerExtraDevtoolsMessage extends LeaderWorkerInnerExtraDevtoolsMessage_base {
|
|
324
324
|
}
|
|
325
325
|
export declare const LeaderWorkerInnerRequest: Schema.Union<[typeof LeaderWorkerInnerInitialMessage, typeof LeaderWorkerInnerBootStatusStream, typeof LeaderWorkerInnerPullStream, typeof LeaderWorkerInnerStreamEvents, typeof LeaderWorkerInnerPushToLeader, typeof LeaderWorkerInnerExport, typeof LeaderWorkerInnerGetRecreateSnapshot, typeof LeaderWorkerInnerExportEventlog, typeof LeaderWorkerInnerGetLeaderHead, typeof LeaderWorkerInnerGetLeaderSyncState, typeof LeaderWorkerInnerSyncStateStream, typeof LeaderWorkerInnerGetNetworkStatus, typeof LeaderWorkerInnerNetworkStatusStream, typeof LeaderWorkerInnerShutdown, typeof LeaderWorkerInnerExtraDevtoolsMessage]>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker-schema.d.ts","sourceRoot":"","sources":["../src/worker-schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,QAAQ,
|
|
1
|
+
{"version":3,"file":"worker-schema.d.ts","sourceRoot":"","sources":["../src/worker-schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,QAAQ,EAIR,SAAS,EACT,YAAY,EACb,MAAM,mBAAmB,CAAA;AAE1B,OAAO,EAAE,mBAAmB,EAAkB,MAAM,0BAA0B,CAAA;AAC9E,OAAO,EAAE,MAAM,EAAgB,MAAM,yBAAyB,CAAA;AAE9D,eAAO,MAAM,UAAU;;;;;GAOtB,CAAA;AAED,eAAO,MAAM,mBAAmB;;IAE9B;;;OAGG;;EAEH,CAAA;AAEF,MAAM,MAAM,mBAAmB,GAAG,OAAO,mBAAmB,CAAC,IAAI,CAAA;AAEjE,eAAO,MAAM,aAAa;;IAExB;;;;OAIG;;EAEH,CAAA;AAEF,MAAM,MAAM,aAAa,GAAG,OAAO,aAAa,CAAC,IAAI,CAAA;AAErD,eAAO,MAAM,WAAW;;IArBtB;;;OAGG;;;;IAQH;;;;OAIG;;IAMsE,CAAA;AAC3E,MAAM,MAAM,WAAW,GAAG,OAAO,WAAW,CAAC,IAAI,CAAA;AACjD,MAAM,MAAM,kBAAkB,GAAG,OAAO,WAAW,CAAC,OAAO,CAAA;AAS3D,eAAO,MAAM,kBAAkB,gGAAiE,CAAA;AAChG,MAAM,MAAM,kBAAkB,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,SAAS,CAAC,CAAA;;;;;;AAEjE,qBAAa,+BAAgC,SAAQ,oCAOpD;CAAG;;AAEJ,qBAAa,wBAAyB,SAAQ,6BAA6C;CAAG;;;;;;;;QA5C5F;;;WAGG;;;;QAQH;;;;WAIG;;;;;;;;;;;;;;;AA+BL,qBAAa,+BAAgC,SAAQ,oCAuBpD;CAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEJ,qBAAa,iCAAkC,SAAQ,sCAOtD;CAAG;;;;;;;;;;;;;;;;AAEJ,qBAAa,2BAA4B,SAAQ,gCAQ/C;CAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEL,qBAAa,6BAA8B,SAAQ,kCAOlD;CAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEJ,qBAAa,6BAA8B,SAAQ,kCASlD;CAAG;;;;AAEJ,qBAAa,uBAAwB,SAAQ,4BAI3C;CAAG;;;;cAOsC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;;;;;;;;;;;AALjF,qBAAa,oCAAqC,SAAQ,yCAUzD;CAAG;;;;AAEJ,qBAAa,+BAAgC,SAAQ,oCAOpD;CAAG;;;;;;;;;;;;AAEJ,qBAAa,8BAA+B,SAAQ,mCAOnD;CAAG;;;;AAEJ,qBAAa,mCAAoC,SAAQ,wCAOxD;CAAG;;;;AAEJ,qBAAa,gCAAiC,SAAQ,qCAOrD;CAAG;;;;;;;;;;AAEJ,qBAAa,iCAAkC,SAAQ,sCAOtD;CAAG;;;;;;;;;;AAEJ,qBAAa,oCAAqC,SAAQ,yCAOzD;CAAG;;;;AAEJ,qBAAa,yBAA0B,SAAQ,8BAI7C;CAAG;;;;;;;;;;;;;;;;;;;;;;;;;AAEL,qBAAa,qCAAsC,SAAQ,0CAS1D;CAAG;AAEJ,eAAO,MAAM,wBAAwB,0mBAgBpC,CAAA;AACD,MAAM,MAAM,wBAAwB,GAAG,OAAO,wBAAwB,CAAC,IAAI,CAAA"}
|
package/dist/worker-schema.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { BootStatus, Devtools,
|
|
1
|
+
import { BootStatus, Devtools, RejectedPushError, MigrationsReport, SyncBackend, SyncState, UnknownError, } from '@livestore/common';
|
|
2
2
|
import { StreamEventsOptionsFields } from '@livestore/common/leader-thread';
|
|
3
3
|
import { EventSequenceNumber, LiveStoreEvent } from '@livestore/common/schema';
|
|
4
4
|
import { Schema, Transferable } from '@livestore/utils/effect';
|
|
@@ -36,7 +36,7 @@ export const SyncBackendOptions = Schema.Record({ key: Schema.String, value: Sch
|
|
|
36
36
|
export class LeaderWorkerOuterInitialMessage extends Schema.TaggedRequest()('InitialMessage', {
|
|
37
37
|
payload: { port: Transferable.MessagePort },
|
|
38
38
|
success: Schema.Void,
|
|
39
|
-
failure:
|
|
39
|
+
failure: Schema.Never,
|
|
40
40
|
}) {
|
|
41
41
|
}
|
|
42
42
|
export class LeaderWorkerOuterRequest extends Schema.Union(LeaderWorkerOuterInitialMessage) {
|
|
@@ -63,7 +63,7 @@ export class LeaderWorkerInnerInitialMessage extends Schema.TaggedRequest()('Ini
|
|
|
63
63
|
export class LeaderWorkerInnerBootStatusStream extends Schema.TaggedRequest()('BootStatusStream', {
|
|
64
64
|
payload: {},
|
|
65
65
|
success: BootStatus,
|
|
66
|
-
failure:
|
|
66
|
+
failure: Schema.Never,
|
|
67
67
|
}) {
|
|
68
68
|
}
|
|
69
69
|
export class LeaderWorkerInnerPullStream extends Schema.TaggedRequest()('PullStream', {
|
|
@@ -73,13 +73,13 @@ export class LeaderWorkerInnerPullStream extends Schema.TaggedRequest()('PullStr
|
|
|
73
73
|
success: Schema.Struct({
|
|
74
74
|
payload: SyncState.PayloadUpstream,
|
|
75
75
|
}),
|
|
76
|
-
failure:
|
|
76
|
+
failure: Schema.Never,
|
|
77
77
|
}) {
|
|
78
78
|
}
|
|
79
79
|
export class LeaderWorkerInnerStreamEvents extends Schema.TaggedRequest()('StreamEvents', {
|
|
80
80
|
payload: StreamEventsOptionsFields,
|
|
81
81
|
success: LiveStoreEvent.Client.Encoded,
|
|
82
|
-
failure:
|
|
82
|
+
failure: Schema.Never,
|
|
83
83
|
}) {
|
|
84
84
|
}
|
|
85
85
|
export class LeaderWorkerInnerPushToLeader extends Schema.TaggedRequest()('PushToLeader', {
|
|
@@ -87,13 +87,13 @@ export class LeaderWorkerInnerPushToLeader extends Schema.TaggedRequest()('PushT
|
|
|
87
87
|
batch: Schema.Array(Schema.typeSchema(LiveStoreEvent.Client.Encoded)),
|
|
88
88
|
},
|
|
89
89
|
success: Schema.Void,
|
|
90
|
-
failure:
|
|
90
|
+
failure: RejectedPushError,
|
|
91
91
|
}) {
|
|
92
92
|
}
|
|
93
93
|
export class LeaderWorkerInnerExport extends Schema.TaggedRequest()('Export', {
|
|
94
94
|
payload: {},
|
|
95
95
|
success: Transferable.Uint8Array,
|
|
96
|
-
failure:
|
|
96
|
+
failure: Schema.Never,
|
|
97
97
|
}) {
|
|
98
98
|
}
|
|
99
99
|
export class LeaderWorkerInnerGetRecreateSnapshot extends Schema.TaggedRequest()('GetRecreateSnapshot', {
|
|
@@ -102,49 +102,49 @@ export class LeaderWorkerInnerGetRecreateSnapshot extends Schema.TaggedRequest()
|
|
|
102
102
|
snapshot: Transferable.Uint8Array,
|
|
103
103
|
migrationsReport: MigrationsReport,
|
|
104
104
|
}),
|
|
105
|
-
failure:
|
|
105
|
+
failure: Schema.Never,
|
|
106
106
|
}) {
|
|
107
107
|
}
|
|
108
108
|
export class LeaderWorkerInnerExportEventlog extends Schema.TaggedRequest()('ExportEventlog', {
|
|
109
109
|
payload: {},
|
|
110
110
|
success: Transferable.Uint8Array,
|
|
111
|
-
failure:
|
|
111
|
+
failure: Schema.Never,
|
|
112
112
|
}) {
|
|
113
113
|
}
|
|
114
114
|
export class LeaderWorkerInnerGetLeaderHead extends Schema.TaggedRequest()('GetLeaderHead', {
|
|
115
115
|
payload: {},
|
|
116
116
|
success: Schema.typeSchema(EventSequenceNumber.Client.Composite),
|
|
117
|
-
failure:
|
|
117
|
+
failure: Schema.Never,
|
|
118
118
|
}) {
|
|
119
119
|
}
|
|
120
120
|
export class LeaderWorkerInnerGetLeaderSyncState extends Schema.TaggedRequest()('GetLeaderSyncState', {
|
|
121
121
|
payload: {},
|
|
122
122
|
success: SyncState.SyncState,
|
|
123
|
-
failure:
|
|
123
|
+
failure: Schema.Never,
|
|
124
124
|
}) {
|
|
125
125
|
}
|
|
126
126
|
export class LeaderWorkerInnerSyncStateStream extends Schema.TaggedRequest()('SyncStateStream', {
|
|
127
127
|
payload: {},
|
|
128
128
|
success: SyncState.SyncState,
|
|
129
|
-
failure:
|
|
129
|
+
failure: Schema.Never,
|
|
130
130
|
}) {
|
|
131
131
|
}
|
|
132
132
|
export class LeaderWorkerInnerGetNetworkStatus extends Schema.TaggedRequest()('GetNetworkStatus', {
|
|
133
133
|
payload: {},
|
|
134
134
|
success: SyncBackend.NetworkStatus,
|
|
135
|
-
failure:
|
|
135
|
+
failure: Schema.Never,
|
|
136
136
|
}) {
|
|
137
137
|
}
|
|
138
138
|
export class LeaderWorkerInnerNetworkStatusStream extends Schema.TaggedRequest()('NetworkStatusStream', {
|
|
139
139
|
payload: {},
|
|
140
140
|
success: SyncBackend.NetworkStatus,
|
|
141
|
-
failure:
|
|
141
|
+
failure: Schema.Never,
|
|
142
142
|
}) {
|
|
143
143
|
}
|
|
144
144
|
export class LeaderWorkerInnerShutdown extends Schema.TaggedRequest()('Shutdown', {
|
|
145
145
|
payload: {},
|
|
146
146
|
success: Schema.Void,
|
|
147
|
-
failure:
|
|
147
|
+
failure: Schema.Never,
|
|
148
148
|
}) {
|
|
149
149
|
}
|
|
150
150
|
export class LeaderWorkerInnerExtraDevtoolsMessage extends Schema.TaggedRequest()('ExtraDevtoolsMessage', {
|
|
@@ -152,7 +152,7 @@ export class LeaderWorkerInnerExtraDevtoolsMessage extends Schema.TaggedRequest(
|
|
|
152
152
|
message: Devtools.Leader.MessageToApp,
|
|
153
153
|
},
|
|
154
154
|
success: Schema.Void,
|
|
155
|
-
failure:
|
|
155
|
+
failure: Schema.Never,
|
|
156
156
|
}) {
|
|
157
157
|
}
|
|
158
158
|
export const LeaderWorkerInnerRequest = Schema.Union(LeaderWorkerInnerInitialMessage, LeaderWorkerInnerBootStatusStream, LeaderWorkerInnerPullStream, LeaderWorkerInnerStreamEvents, LeaderWorkerInnerPushToLeader, LeaderWorkerInnerExport, LeaderWorkerInnerGetRecreateSnapshot, LeaderWorkerInnerExportEventlog, LeaderWorkerInnerGetLeaderHead, LeaderWorkerInnerGetLeaderSyncState, LeaderWorkerInnerSyncStateStream, LeaderWorkerInnerGetNetworkStatus, LeaderWorkerInnerNetworkStatusStream, LeaderWorkerInnerShutdown, LeaderWorkerInnerExtraDevtoolsMessage);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker-schema.js","sourceRoot":"","sources":["../src/worker-schema.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EACV,QAAQ,EACR,
|
|
1
|
+
{"version":3,"file":"worker-schema.js","sourceRoot":"","sources":["../src/worker-schema.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,16 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@livestore/adapter-node",
|
|
3
|
-
"version": "0.4.0-dev.
|
|
3
|
+
"version": "0.4.0-dev.23",
|
|
4
|
+
"license": "Apache-2.0",
|
|
5
|
+
"repository": {
|
|
6
|
+
"type": "git",
|
|
7
|
+
"url": "git+https://github.com/livestorejs/livestore.git"
|
|
8
|
+
},
|
|
9
|
+
"files": [
|
|
10
|
+
"dist",
|
|
11
|
+
"package.json",
|
|
12
|
+
"src"
|
|
13
|
+
],
|
|
4
14
|
"type": "module",
|
|
5
15
|
"sideEffects": false,
|
|
6
16
|
"exports": {
|
|
@@ -8,29 +18,59 @@
|
|
|
8
18
|
"./devtools": "./dist/devtools/mod.js",
|
|
9
19
|
"./worker": "./dist/make-leader-worker.js"
|
|
10
20
|
},
|
|
21
|
+
"publishConfig": {
|
|
22
|
+
"access": "public"
|
|
23
|
+
},
|
|
11
24
|
"dependencies": {
|
|
12
|
-
"@livestore/devtools-vite": "0.4.0-dev.22",
|
|
13
25
|
"@opentelemetry/api": "1.9.0",
|
|
14
|
-
"
|
|
15
|
-
"@livestore/
|
|
16
|
-
"@livestore/
|
|
17
|
-
"@livestore/sqlite-wasm": "0.4.0-dev.
|
|
18
|
-
"@livestore/webmesh": "0.4.0-dev.22"
|
|
26
|
+
"@livestore/common": "^0.4.0-dev.23",
|
|
27
|
+
"@livestore/utils": "^0.4.0-dev.23",
|
|
28
|
+
"@livestore/webmesh": "^0.4.0-dev.23",
|
|
29
|
+
"@livestore/sqlite-wasm": "^0.4.0-dev.23"
|
|
19
30
|
},
|
|
20
31
|
"devDependencies": {
|
|
21
|
-
"@
|
|
22
|
-
"@rollup/plugin-
|
|
23
|
-
"@rollup/plugin-
|
|
24
|
-
"rollup": "
|
|
32
|
+
"@livestore/devtools-vite": "0.4.0-dev.23",
|
|
33
|
+
"@rollup/plugin-commonjs": "28.0.6",
|
|
34
|
+
"@rollup/plugin-node-resolve": "16.0.1",
|
|
35
|
+
"@rollup/plugin-terser": "0.4.4",
|
|
36
|
+
"@types/node": "25.3.3",
|
|
37
|
+
"rollup": "4.49.0",
|
|
38
|
+
"vite": "7.3.1"
|
|
25
39
|
},
|
|
26
|
-
"
|
|
27
|
-
"
|
|
28
|
-
"
|
|
29
|
-
"
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
"
|
|
40
|
+
"peerDependencies": {
|
|
41
|
+
"@effect/ai": "^0.35.0",
|
|
42
|
+
"@effect/cli": "^0.75.1",
|
|
43
|
+
"@effect/cluster": "^0.58.2",
|
|
44
|
+
"@effect/experimental": "^0.60.0",
|
|
45
|
+
"@effect/opentelemetry": "^0.63.0",
|
|
46
|
+
"@effect/platform": "^0.96.1",
|
|
47
|
+
"@effect/platform-browser": "^0.76.0",
|
|
48
|
+
"@effect/platform-bun": "^0.89.0",
|
|
49
|
+
"@effect/platform-node": "^0.106.0",
|
|
50
|
+
"@effect/printer": "^0.49.0",
|
|
51
|
+
"@effect/printer-ansi": "^0.49.0",
|
|
52
|
+
"@effect/rpc": "^0.75.1",
|
|
53
|
+
"@effect/sql": "^0.51.1",
|
|
54
|
+
"@effect/typeclass": "^0.40.0",
|
|
55
|
+
"@effect/vitest": "^0.29.0",
|
|
56
|
+
"@opentelemetry/api": "^1.9.0",
|
|
57
|
+
"@opentelemetry/resources": "^2.2.0",
|
|
58
|
+
"@standard-schema/spec": "^1.1.0",
|
|
59
|
+
"effect": "^3.21.2"
|
|
60
|
+
},
|
|
61
|
+
"$genie": {
|
|
62
|
+
"source": "package.json.genie.ts",
|
|
63
|
+
"warning": "DO NOT EDIT - changes will be overwritten",
|
|
64
|
+
"workspaceClosureDirs": [
|
|
65
|
+
"packages/@livestore/adapter-node",
|
|
66
|
+
"packages/@livestore/common",
|
|
67
|
+
"packages/@livestore/common-cf",
|
|
68
|
+
"packages/@livestore/sqlite-wasm",
|
|
69
|
+
"packages/@livestore/utils",
|
|
70
|
+
"packages/@livestore/utils-dev",
|
|
71
|
+
"packages/@livestore/wa-sqlite",
|
|
72
|
+
"packages/@livestore/webmesh"
|
|
73
|
+
]
|
|
34
74
|
},
|
|
35
75
|
"scripts": {
|
|
36
76
|
"test": "echo No tests yet"
|
|
@@ -1,15 +1,17 @@
|
|
|
1
1
|
import { hostname } from 'node:os'
|
|
2
2
|
import path from 'node:path'
|
|
3
|
+
import type { URL } from 'node:url'
|
|
3
4
|
import * as WT from 'node:worker_threads'
|
|
5
|
+
|
|
4
6
|
import {
|
|
5
7
|
type Adapter,
|
|
6
8
|
type BootStatus,
|
|
7
9
|
ClientSessionLeaderThreadProxy,
|
|
8
10
|
IntentionalShutdownCause,
|
|
11
|
+
isWorkerTransportError,
|
|
9
12
|
type LockStatus,
|
|
10
13
|
type MakeSqliteDb,
|
|
11
14
|
makeClientSession,
|
|
12
|
-
type SyncError,
|
|
13
15
|
type SyncOptions,
|
|
14
16
|
UnknownError,
|
|
15
17
|
} from '@livestore/common'
|
|
@@ -27,7 +29,7 @@ import {
|
|
|
27
29
|
Fiber,
|
|
28
30
|
FileSystem,
|
|
29
31
|
Layer,
|
|
30
|
-
|
|
32
|
+
Option,
|
|
31
33
|
Queue,
|
|
32
34
|
Schedule,
|
|
33
35
|
Schema,
|
|
@@ -35,7 +37,6 @@ import {
|
|
|
35
37
|
Subscribable,
|
|
36
38
|
SubscriptionRef,
|
|
37
39
|
Worker,
|
|
38
|
-
WorkerError,
|
|
39
40
|
} from '@livestore/utils/effect'
|
|
40
41
|
import { PlatformNode } from '@livestore/utils/node'
|
|
41
42
|
import * as Webmesh from '@livestore/webmesh'
|
|
@@ -232,7 +233,7 @@ const makeAdapterImpl = ({
|
|
|
232
233
|
yield* shutdownChannel.listen.pipe(
|
|
233
234
|
Stream.flatten(),
|
|
234
235
|
Stream.tap((cause) =>
|
|
235
|
-
shutdown(cause._tag === '
|
|
236
|
+
shutdown(cause._tag === 'IntentionalShutdownCause' ? Exit.succeed(cause) : Exit.fail(cause)),
|
|
236
237
|
),
|
|
237
238
|
Stream.runDrain,
|
|
238
239
|
Effect.interruptible,
|
|
@@ -246,7 +247,7 @@ const makeAdapterImpl = ({
|
|
|
246
247
|
const lockStatus = yield* SubscriptionRef.make<LockStatus>('has-lock')
|
|
247
248
|
|
|
248
249
|
const devtoolsOptions: WorkerSchema.LeaderWorkerInnerInitialMessage['devtools'] =
|
|
249
|
-
devtoolsEnabled && devtoolsOptionsInput !== undefined
|
|
250
|
+
devtoolsEnabled === true && devtoolsOptionsInput !== undefined
|
|
250
251
|
? {
|
|
251
252
|
enabled: true,
|
|
252
253
|
schemaPath:
|
|
@@ -297,7 +298,7 @@ const makeAdapterImpl = ({
|
|
|
297
298
|
sqliteDb: syncInMemoryDb,
|
|
298
299
|
webmeshMode: 'proxy',
|
|
299
300
|
connectWebmeshNode: Effect.fnUntraced(function* ({ webmeshNode }) {
|
|
300
|
-
if (devtoolsOptions.enabled) {
|
|
301
|
+
if (devtoolsOptions.enabled === true) {
|
|
301
302
|
yield* Webmesh.connectViaWebSocket({
|
|
302
303
|
node: webmeshNode,
|
|
303
304
|
url: `ws://${devtoolsOptions.host}:${devtoolsOptions.port}`,
|
|
@@ -446,7 +447,7 @@ const makeWorkerLeaderThread = ({
|
|
|
446
447
|
syncPayloadEncoded,
|
|
447
448
|
testing,
|
|
448
449
|
}: {
|
|
449
|
-
shutdown: (cause: Exit.Exit<IntentionalShutdownCause, UnknownError
|
|
450
|
+
shutdown: (cause: Exit.Exit<IntentionalShutdownCause, UnknownError>) => Effect.Effect<void>
|
|
450
451
|
storeId: string
|
|
451
452
|
clientId: string
|
|
452
453
|
sessionId: string
|
|
@@ -462,8 +463,8 @@ const makeWorkerLeaderThread = ({
|
|
|
462
463
|
}) =>
|
|
463
464
|
Effect.gen(function* () {
|
|
464
465
|
const nodeWorker = new WT.Worker(workerUrl, {
|
|
465
|
-
execArgv: process.env.DEBUG_WORKER ? ['--inspect --enable-source-maps'] : ['--enable-source-maps'],
|
|
466
|
-
argv: [Schema.
|
|
466
|
+
execArgv: process.env.DEBUG_WORKER !== undefined ? ['--inspect --enable-source-maps'] : ['--enable-source-maps'],
|
|
467
|
+
argv: [yield* Schema.encode(WorkerSchema.WorkerArgv)({ storeId, clientId, sessionId, extraArgs: workerExtraArgs }).pipe(Effect.orDie)],
|
|
467
468
|
})
|
|
468
469
|
const nodeWorkerLayer = yield* Layer.build(PlatformNode.NodeWorker.layer(() => nodeWorker))
|
|
469
470
|
|
|
@@ -485,47 +486,30 @@ const makeWorkerLeaderThread = ({
|
|
|
485
486
|
Effect.withSpan('@livestore/adapter-node:adapter:setupLeaderThread'),
|
|
486
487
|
)
|
|
487
488
|
|
|
488
|
-
const runInWorker = <
|
|
489
|
-
req:
|
|
490
|
-
):
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
(worker.executeEffect(req) as any).pipe(
|
|
489
|
+
const runInWorker = <A, I, E, EI, R>(
|
|
490
|
+
req: WorkerSchema.LeaderWorkerInnerRequest & Schema.WithResult<A, I, E, EI, R>,
|
|
491
|
+
): Effect.Effect<A, E, R> =>
|
|
492
|
+
worker.executeEffect(req).pipe(
|
|
493
|
+
Effect.catchIf(isWorkerTransportError, (e) => Effect.die(e)),
|
|
494
494
|
Effect.logWarnIfTakesLongerThan({
|
|
495
495
|
label: `@livestore/adapter-node:client-session:runInWorker:${req._tag}`,
|
|
496
496
|
duration: 2000,
|
|
497
497
|
}),
|
|
498
498
|
Effect.withSpan(`@livestore/adapter-node:client-session:runInWorker:${req._tag}`),
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
),
|
|
506
|
-
Effect.catchAllDefect((cause) => new UnknownError({ cause })),
|
|
507
|
-
) as any
|
|
508
|
-
|
|
509
|
-
const runInWorkerStream = <TReq extends typeof WorkerSchema.LeaderWorkerInnerRequest.Type>(
|
|
510
|
-
req: TReq,
|
|
511
|
-
): TReq extends Schema.WithResult<infer A, infer _I, infer _E, infer _EI, infer R>
|
|
512
|
-
? Stream.Stream<A, UnknownError, R>
|
|
513
|
-
: never =>
|
|
514
|
-
worker.execute(req as any).pipe(
|
|
515
|
-
Stream.mapError((cause) =>
|
|
516
|
-
Schema.is(UnknownError)(cause)
|
|
517
|
-
? cause
|
|
518
|
-
: ParseResult.isParseError(cause) || Schema.is(WorkerError.WorkerError)(cause)
|
|
519
|
-
? new UnknownError({ cause })
|
|
520
|
-
: cause,
|
|
521
|
-
),
|
|
499
|
+
)
|
|
500
|
+
|
|
501
|
+
const runInWorkerStream = <A, I, E, EI, R>(
|
|
502
|
+
req: WorkerSchema.LeaderWorkerInnerRequest & Schema.WithResult<A, I, E, EI, R>,
|
|
503
|
+
): Stream.Stream<A, E, R> =>
|
|
504
|
+
worker.execute(req).pipe(
|
|
505
|
+
Stream.refineOrDie((e) => isWorkerTransportError(e) === true ? Option.none() : Option.some(e)),
|
|
522
506
|
Stream.withSpan(`@livestore/adapter-node:client-session:runInWorkerStream:${req._tag}`),
|
|
523
|
-
)
|
|
507
|
+
)
|
|
524
508
|
|
|
525
509
|
const bootStatusFiber = yield* runInWorkerStream(new WorkerSchema.LeaderWorkerInnerBootStatusStream()).pipe(
|
|
526
510
|
Stream.tap((bootStatus) => Queue.offer(bootStatusQueue, bootStatus)),
|
|
527
511
|
Stream.runDrain,
|
|
528
|
-
Effect.tapErrorCause((cause) => (Cause.isInterruptedOnly(cause) ? Effect.void : shutdown(Exit.failCause(cause)))),
|
|
512
|
+
Effect.tapErrorCause((cause) => (Cause.isInterruptedOnly(cause) === true ? Effect.void : shutdown(Exit.failCause(cause)))),
|
|
529
513
|
Effect.interruptible,
|
|
530
514
|
Effect.tapCauseLogPretty,
|
|
531
515
|
Effect.forkScoped,
|
|
@@ -540,8 +524,7 @@ const makeWorkerLeaderThread = ({
|
|
|
540
524
|
const initialLeaderHead = yield* runInWorker(new WorkerSchema.LeaderWorkerInnerGetLeaderHead())
|
|
541
525
|
|
|
542
526
|
const bootResult = yield* runInWorker(new WorkerSchema.LeaderWorkerInnerGetRecreateSnapshot()).pipe(
|
|
543
|
-
Effect.
|
|
544
|
-
UnknownError.mapToUnknownError,
|
|
527
|
+
Effect.timeoutOrDie(10_000),
|
|
545
528
|
Effect.withSpan('@livestore/adapter-node:client-session:export'),
|
|
546
529
|
)
|
|
547
530
|
|
|
@@ -568,21 +551,18 @@ const makeWorkerLeaderThread = ({
|
|
|
568
551
|
storageMode: 'persisted',
|
|
569
552
|
},
|
|
570
553
|
export: runInWorker(new WorkerSchema.LeaderWorkerInnerExport()).pipe(
|
|
571
|
-
Effect.
|
|
572
|
-
UnknownError.mapToUnknownError,
|
|
554
|
+
Effect.timeoutOrDie(10_000),
|
|
573
555
|
Effect.withSpan('@livestore/adapter-node:client-session:export'),
|
|
574
556
|
),
|
|
575
557
|
getEventlogData: Effect.dieMessage('Not implemented'),
|
|
576
558
|
syncState: Subscribable.make({
|
|
577
559
|
get: runInWorker(new WorkerSchema.LeaderWorkerInnerGetLeaderSyncState()).pipe(
|
|
578
|
-
UnknownError.mapToUnknownError,
|
|
579
560
|
Effect.withSpan('@livestore/adapter-node:client-session:getLeaderSyncState'),
|
|
580
561
|
),
|
|
581
562
|
changes: runInWorkerStream(new WorkerSchema.LeaderWorkerInnerSyncStateStream()).pipe(Stream.orDie),
|
|
582
563
|
}),
|
|
583
564
|
sendDevtoolsMessage: (message) =>
|
|
584
565
|
runInWorker(new WorkerSchema.LeaderWorkerInnerExtraDevtoolsMessage({ message })).pipe(
|
|
585
|
-
UnknownError.mapToUnknownError,
|
|
586
566
|
Effect.withSpan('@livestore/adapter-node:client-session:devtoolsMessageForLeader'),
|
|
587
567
|
),
|
|
588
568
|
networkStatus: Subscribable.make({
|
|
@@ -49,11 +49,12 @@ export const startDevtoolsServer = ({
|
|
|
49
49
|
Effect.gen(function* () {
|
|
50
50
|
const viteMiddleware = yield* makeViteMiddleware({
|
|
51
51
|
mode: { _tag: 'node', url: `http://${host}:${port}` },
|
|
52
|
-
schemaPath:
|
|
53
|
-
|
|
54
|
-
|
|
52
|
+
schemaPath:
|
|
53
|
+
isReadonlyArray(schemaPath) === true
|
|
54
|
+
? schemaPath.map((schemaPath) => path.resolve(process.cwd(), schemaPath))
|
|
55
|
+
: path.resolve(process.cwd(), schemaPath),
|
|
55
56
|
viteConfig: (viteConfig) => {
|
|
56
|
-
if (LS_DEV) {
|
|
57
|
+
if (LS_DEV === true) {
|
|
57
58
|
viteConfig.server ??= {}
|
|
58
59
|
viteConfig.server.fs ??= {}
|
|
59
60
|
viteConfig.server.fs.strict = false
|
|
@@ -73,7 +74,7 @@ export const startDevtoolsServer = ({
|
|
|
73
74
|
const handler = Effect.gen(function* () {
|
|
74
75
|
const req = yield* HttpServerRequest.HttpServerRequest
|
|
75
76
|
|
|
76
|
-
if (Headers.has(req.headers, 'upgrade')) {
|
|
77
|
+
if (Headers.has(req.headers, 'upgrade') === true) {
|
|
77
78
|
// yield* Effect.logDebug(`WS Relay ${relayNodeName}: WS upgrade request ${req.url}`)
|
|
78
79
|
|
|
79
80
|
const socket = yield* req.upgrade
|
|
@@ -91,7 +92,7 @@ export const startDevtoolsServer = ({
|
|
|
91
92
|
.addEdge({ target: from, edgeChannel: webChannel, replaceIfExists: true })
|
|
92
93
|
.pipe(Effect.acquireRelease(() => node.removeEdge(from).pipe(Effect.orDie)))
|
|
93
94
|
|
|
94
|
-
if (LS_DEV) {
|
|
95
|
+
if (LS_DEV === true) {
|
|
95
96
|
yield* Effect.log(`WS Relay ${relayNodeName}: added edge from '${from}'`)
|
|
96
97
|
yield* Effect.addFinalizerLog(`WS Relay ${relayNodeName}: removed edge from '${from}'`)
|
|
97
98
|
}
|
|
@@ -106,7 +107,7 @@ export const startDevtoolsServer = ({
|
|
|
106
107
|
} else {
|
|
107
108
|
if (req.url === '/' || req.url === '') {
|
|
108
109
|
return HttpServerResponse.redirect('/_livestore/node')
|
|
109
|
-
} else if (shouldRouteToVite(req.url)) {
|
|
110
|
+
} else if (shouldRouteToVite(req.url) === true) {
|
|
110
111
|
// Here we're delegating to the Vite middleware
|
|
111
112
|
|
|
112
113
|
// TODO replace this once @effect/platform-node supports Node HTTP middlewares
|
|
@@ -124,9 +125,10 @@ export const startDevtoolsServer = ({
|
|
|
124
125
|
return HttpServerResponse.text('Not found')
|
|
125
126
|
}).pipe(Effect.tapCauseLogPretty, Effect.interruptible)
|
|
126
127
|
|
|
127
|
-
const sessionSuffix =
|
|
128
|
-
|
|
129
|
-
|
|
128
|
+
const sessionSuffix =
|
|
129
|
+
clientSessionInfo !== undefined
|
|
130
|
+
? `/${clientSessionInfo.storeId}/${clientSessionInfo.clientId}/${clientSessionInfo.sessionId}/${clientSessionInfo.schemaAlias}`
|
|
131
|
+
: '?autoconnect'
|
|
130
132
|
|
|
131
133
|
// Use `localhost` instead of `0.0.0.0` as it doesn't have the `navigator.locks` web adapter limitation (https://share.cleanshot.com/nHBnmk6S)
|
|
132
134
|
const maybeLocalhost = host === '0.0.0.0' ? 'localhost' : host
|
package/src/devtools/mod.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
export { startDevtoolsServer } from './devtools-server.ts'
|
|
2
2
|
export type { ViteDevtoolsOptions } from './vite-dev-server.ts'
|
|
3
|
-
export { makeViteMiddleware } from './vite-dev-server.ts'
|
|
3
|
+
export { DevtoolsViteNotInstalledError, makeViteMiddleware } from './vite-dev-server.ts'
|