@effect/platform-node 0.75.4 → 0.76.0
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/NodeClusterRunnerHttp/package.json +6 -0
- package/NodeClusterRunnerSocket/package.json +6 -0
- package/NodeClusterShardManagerHttp/package.json +6 -0
- package/NodeClusterShardManagerSocket/package.json +6 -0
- package/NodeSocketServer/package.json +6 -0
- package/dist/cjs/NodeClusterRunnerHttp.js +51 -0
- package/dist/cjs/NodeClusterRunnerHttp.js.map +1 -0
- package/dist/cjs/NodeClusterRunnerSocket.js +17 -0
- package/dist/cjs/NodeClusterRunnerSocket.js.map +1 -0
- package/dist/cjs/NodeClusterShardManagerHttp.js +42 -0
- package/dist/cjs/NodeClusterShardManagerHttp.js.map +1 -0
- package/dist/cjs/NodeClusterShardManagerSocket.js +17 -0
- package/dist/cjs/NodeClusterShardManagerSocket.js.map +1 -0
- package/dist/cjs/NodeSocketServer.js +17 -0
- package/dist/cjs/NodeSocketServer.js.map +1 -0
- package/dist/cjs/NodeWorker.js +6 -1
- package/dist/cjs/NodeWorker.js.map +1 -1
- package/dist/cjs/index.js +11 -1
- package/dist/cjs/internal/worker.js +4 -1
- package/dist/cjs/internal/worker.js.map +1 -1
- package/dist/cjs/internal/workerRunner.js +6 -3
- package/dist/cjs/internal/workerRunner.js.map +1 -1
- package/dist/dts/NodeClusterRunnerHttp.d.ts +29 -0
- package/dist/dts/NodeClusterRunnerHttp.d.ts.map +1 -0
- package/dist/dts/NodeClusterRunnerSocket.d.ts +9 -0
- package/dist/dts/NodeClusterRunnerSocket.d.ts.map +1 -0
- package/dist/dts/NodeClusterShardManagerHttp.d.ts +27 -0
- package/dist/dts/NodeClusterShardManagerHttp.d.ts.map +1 -0
- package/dist/dts/NodeClusterShardManagerSocket.d.ts +9 -0
- package/dist/dts/NodeClusterShardManagerSocket.d.ts.map +1 -0
- package/dist/dts/NodeSocketServer.d.ts +8 -0
- package/dist/dts/NodeSocketServer.d.ts.map +1 -0
- package/dist/dts/NodeWorker.d.ts +6 -1
- package/dist/dts/NodeWorker.d.ts.map +1 -1
- package/dist/dts/index.d.ts +20 -0
- package/dist/dts/index.d.ts.map +1 -1
- package/dist/esm/NodeClusterRunnerHttp.js +41 -0
- package/dist/esm/NodeClusterRunnerHttp.js.map +1 -0
- package/dist/esm/NodeClusterRunnerSocket.js +9 -0
- package/dist/esm/NodeClusterRunnerSocket.js.map +1 -0
- package/dist/esm/NodeClusterShardManagerHttp.js +32 -0
- package/dist/esm/NodeClusterShardManagerHttp.js.map +1 -0
- package/dist/esm/NodeClusterShardManagerSocket.js +9 -0
- package/dist/esm/NodeClusterShardManagerSocket.js.map +1 -0
- package/dist/esm/NodeSocketServer.js +8 -0
- package/dist/esm/NodeSocketServer.js.map +1 -0
- package/dist/esm/NodeWorker.js +5 -0
- package/dist/esm/NodeWorker.js.map +1 -1
- package/dist/esm/index.js +20 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/internal/worker.js +2 -0
- package/dist/esm/internal/worker.js.map +1 -1
- package/dist/esm/internal/workerRunner.js +6 -3
- package/dist/esm/internal/workerRunner.js.map +1 -1
- package/package.json +47 -4
- package/src/NodeClusterRunnerHttp.ts +93 -0
- package/src/NodeClusterRunnerSocket.ts +9 -0
- package/src/NodeClusterShardManagerHttp.ts +72 -0
- package/src/NodeClusterShardManagerSocket.ts +9 -0
- package/src/NodeSocketServer.ts +8 -0
- package/src/NodeWorker.ts +9 -1
- package/src/index.ts +25 -0
- package/src/internal/worker.ts +4 -0
- package/src/internal/workerRunner.ts +7 -4
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NodeClusterRunnerSocket.js","names":[],"sources":["../../src/NodeClusterRunnerSocket.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAIA;;;;AAIA,cAAc,sDAAsD","ignoreList":[]}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @since 1.0.0
|
|
3
|
+
*/
|
|
4
|
+
import * as HttpShardManager from "@effect/cluster/HttpShardManager";
|
|
5
|
+
import * as ShardingConfig from "@effect/cluster/ShardingConfig";
|
|
6
|
+
import * as ShardManager from "@effect/cluster/ShardManager";
|
|
7
|
+
import * as ShardStorage from "@effect/cluster/ShardStorage";
|
|
8
|
+
import * as SqlShardStorage from "@effect/cluster/SqlShardStorage";
|
|
9
|
+
import * as RpcSerialization from "@effect/rpc/RpcSerialization";
|
|
10
|
+
import * as Effect from "effect/Effect";
|
|
11
|
+
import * as Layer from "effect/Layer";
|
|
12
|
+
import { createServer } from "node:http";
|
|
13
|
+
import * as NodeHttpClient from "./NodeHttpClient.js";
|
|
14
|
+
import * as NodeHttpServer from "./NodeHttpServer.js";
|
|
15
|
+
import * as NodeSocket from "./NodeSocket.js";
|
|
16
|
+
/**
|
|
17
|
+
* @since 1.0.0
|
|
18
|
+
* @category Layers
|
|
19
|
+
*/
|
|
20
|
+
export const layerHttpServer = /*#__PURE__*/Effect.gen(function* () {
|
|
21
|
+
const config = yield* ShardingConfig.ShardingConfig;
|
|
22
|
+
return NodeHttpServer.layer(createServer, config.shardManagerAddress);
|
|
23
|
+
}).pipe(Layer.unwrapEffect);
|
|
24
|
+
/**
|
|
25
|
+
* @since 1.0.0
|
|
26
|
+
* @category Layers
|
|
27
|
+
*/
|
|
28
|
+
export const layer = options => {
|
|
29
|
+
const layer = options.protocol === "http" ? HttpShardManager.layerHttp.pipe(Layer.provide([HttpShardManager.layerRunnerHealthHttp, layerHttpServer]), Layer.provide(NodeHttpClient.layerUndici)) : HttpShardManager.layerWebsocket.pipe(Layer.provide([HttpShardManager.layerRunnerHealthWebsocket, layerHttpServer]), Layer.provide(NodeSocket.layerWebSocketConstructor));
|
|
30
|
+
return layer.pipe(Layer.provide(options?.storage === "sql" ? SqlShardStorage.layer : ShardStorage.layerNoop), Layer.provide([ShardingConfig.layerFromEnv(options.shardingConfig), ShardManager.layerConfigFromEnv, options?.serialization === "ndjson" ? RpcSerialization.layerNdjson : RpcSerialization.layerMsgPack]));
|
|
31
|
+
};
|
|
32
|
+
//# sourceMappingURL=NodeClusterShardManagerHttp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NodeClusterShardManagerHttp.js","names":["HttpShardManager","ShardingConfig","ShardManager","ShardStorage","SqlShardStorage","RpcSerialization","Effect","Layer","createServer","NodeHttpClient","NodeHttpServer","NodeSocket","layerHttpServer","gen","config","layer","shardManagerAddress","pipe","unwrapEffect","options","protocol","layerHttp","provide","layerRunnerHealthHttp","layerUndici","layerWebsocket","layerRunnerHealthWebsocket","layerWebSocketConstructor","storage","layerNoop","layerFromEnv","shardingConfig","layerConfigFromEnv","serialization","layerNdjson","layerMsgPack"],"sources":["../../src/NodeClusterShardManagerHttp.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAGA,OAAO,KAAKA,gBAAgB,MAAM,kCAAkC;AACpE,OAAO,KAAKC,cAAc,MAAM,gCAAgC;AAChE,OAAO,KAAKC,YAAY,MAAM,8BAA8B;AAC5D,OAAO,KAAKC,YAAY,MAAM,8BAA8B;AAC5D,OAAO,KAAKC,eAAe,MAAM,iCAAiC;AAKlE,OAAO,KAAKC,gBAAgB,MAAM,8BAA8B;AAIhE,OAAO,KAAKC,MAAM,MAAM,eAAe;AACvC,OAAO,KAAKC,KAAK,MAAM,cAAc;AACrC,SAASC,YAAY,QAAQ,WAAW;AAExC,OAAO,KAAKC,cAAc,MAAM,qBAAqB;AACrD,OAAO,KAAKC,cAAc,MAAM,qBAAqB;AACrD,OAAO,KAAKC,UAAU,MAAM,iBAAiB;AAE7C;;;;AAIA,OAAO,MAAMC,eAAe,gBAOxBN,MAAM,CAACO,GAAG,CAAC,aAAS;EACtB,MAAMC,MAAM,GAAG,OAAOb,cAAc,CAACA,cAAc;EACnD,OAAOS,cAAc,CAACK,KAAK,CAACP,YAAY,EAAEM,MAAM,CAACE,mBAAmB,CAAC;AACvE,CAAC,CAAC,CAACC,IAAI,CAACV,KAAK,CAACW,YAAY,CAAC;AAE3B;;;;AAIA,OAAO,MAAMH,KAAK,GAAmDI,OAKpE,IAIG;EACF,MAAMJ,KAAK,GAA+BI,OAAO,CAACC,QAAQ,KAAK,MAAM,GACnEpB,gBAAgB,CAACqB,SAAS,CAACJ,IAAI,CAC7BV,KAAK,CAACe,OAAO,CAAC,CAACtB,gBAAgB,CAACuB,qBAAqB,EAAEX,eAAe,CAAC,CAAC,EACxEL,KAAK,CAACe,OAAO,CAACb,cAAc,CAACe,WAAW,CAAC,CAC1C,GACDxB,gBAAgB,CAACyB,cAAc,CAACR,IAAI,CAClCV,KAAK,CAACe,OAAO,CAAC,CAACtB,gBAAgB,CAAC0B,0BAA0B,EAAEd,eAAe,CAAC,CAAC,EAC7EL,KAAK,CAACe,OAAO,CAACX,UAAU,CAACgB,yBAAyB,CAAC,CACpD;EACH,OAAOZ,KAAK,CAACE,IAAI,CACfV,KAAK,CAACe,OAAO,CAACH,OAAO,EAAES,OAAO,KAAK,KAAK,GAAGxB,eAAe,CAACW,KAAK,GAAGZ,YAAY,CAAC0B,SAAS,CAAC,EAC1FtB,KAAK,CAACe,OAAO,CAAC,CACZrB,cAAc,CAAC6B,YAAY,CAACX,OAAO,CAACY,cAAc,CAAC,EACnD7B,YAAY,CAAC8B,kBAAkB,EAC/Bb,OAAO,EAAEc,aAAa,KAAK,QAAQ,GAAG5B,gBAAgB,CAAC6B,WAAW,GAAG7B,gBAAgB,CAAC8B,YAAY,CACnG,CAAC,CACH;AACH,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NodeClusterShardManagerSocket.js","names":[],"sources":["../../src/NodeClusterShardManagerSocket.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAIA;;;;AAIA,cAAc,4DAA4D","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NodeSocketServer.js","names":[],"sources":["../../src/NodeSocketServer.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAIA;;;AAGA,cAAc,+CAA+C","ignoreList":[]}
|
package/dist/esm/NodeWorker.js
CHANGED
|
@@ -14,4 +14,9 @@ export const layerWorker = internal.layerWorker;
|
|
|
14
14
|
* @category layers
|
|
15
15
|
*/
|
|
16
16
|
export const layer = internal.layer;
|
|
17
|
+
/**
|
|
18
|
+
* @since 1.0.0
|
|
19
|
+
* @category layers
|
|
20
|
+
*/
|
|
21
|
+
export const layerPlatform = internal.layerPlatform;
|
|
17
22
|
//# sourceMappingURL=NodeWorker.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NodeWorker.js","names":["internal","layerManager","layerWorker","layer"],"sources":["../../src/NodeWorker.ts"],"sourcesContent":[null],"mappings":"AAMA,OAAO,KAAKA,QAAQ,MAAM,sBAAsB;AAEhD;;;;AAIA,OAAO,MAAMC,YAAY,GAAsCD,QAAQ,CAACC,YAAY;AAEpF;;;;AAIA,OAAO,MAAMC,WAAW,GAAuCF,QAAQ,CAACE,WAAW;AAEnF;;;;AAIA,OAAO,MAAMC,KAAK,
|
|
1
|
+
{"version":3,"file":"NodeWorker.js","names":["internal","layerManager","layerWorker","layer","layerPlatform"],"sources":["../../src/NodeWorker.ts"],"sourcesContent":[null],"mappings":"AAMA,OAAO,KAAKA,QAAQ,MAAM,sBAAsB;AAEhD;;;;AAIA,OAAO,MAAMC,YAAY,GAAsCD,QAAQ,CAACC,YAAY;AAEpF;;;;AAIA,OAAO,MAAMC,WAAW,GAAuCF,QAAQ,CAACE,WAAW;AAEnF;;;;AAIA,OAAO,MAAMC,KAAK,GAEwCH,QAAQ,CAACG,KAAK;AAExE;;;;AAIA,OAAO,MAAMC,aAAa,GAEiCJ,QAAQ,CAACI,aAAa","ignoreList":[]}
|
package/dist/esm/index.js
CHANGED
|
@@ -1,3 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @since 1.0.0
|
|
3
|
+
*/
|
|
4
|
+
export * as NodeClusterRunnerHttp from "./NodeClusterRunnerHttp.js";
|
|
5
|
+
/**
|
|
6
|
+
* @since 1.0.0
|
|
7
|
+
*/
|
|
8
|
+
export * as NodeClusterRunnerSocket from "./NodeClusterRunnerSocket.js";
|
|
9
|
+
/**
|
|
10
|
+
* @since 1.0.0
|
|
11
|
+
*/
|
|
12
|
+
export * as NodeClusterShardManagerHttp from "./NodeClusterShardManagerHttp.js";
|
|
13
|
+
/**
|
|
14
|
+
* @since 1.0.0
|
|
15
|
+
*/
|
|
16
|
+
export * as NodeClusterShardManagerSocket from "./NodeClusterShardManagerSocket.js";
|
|
1
17
|
/**
|
|
2
18
|
* @since 1.0.0
|
|
3
19
|
*/
|
|
@@ -50,6 +66,10 @@ export * as NodeSink from "./NodeSink.js";
|
|
|
50
66
|
* @since 1.0.0
|
|
51
67
|
*/
|
|
52
68
|
export * as NodeSocket from "./NodeSocket.js";
|
|
69
|
+
/**
|
|
70
|
+
* @since 1.0.0
|
|
71
|
+
*/
|
|
72
|
+
export * as NodeSocketServer from "./NodeSocketServer.js";
|
|
53
73
|
/**
|
|
54
74
|
* @since 1.0.0
|
|
55
75
|
*/
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["NodeCommandExecutor","NodeContext","NodeFileSystem","NodeHttpClient","NodeHttpPlatform","NodeHttpServer","NodeHttpServerRequest","NodeKeyValueStore","NodeMultipart","NodePath","NodeRuntime","NodeSink","NodeSocket","NodeStream","NodeTerminal","NodeWorker","NodeWorkerRunner","Undici"],"sources":["../../src/index.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAGA,OAAO,KAAKA,mBAAmB,MAAM,0BAA0B;AAE/D;;;AAGA,OAAO,KAAKC,WAAW,MAAM,kBAAkB;AAE/C;;;AAGA,OAAO,KAAKC,cAAc,MAAM,qBAAqB;AAErD;;;AAGA,OAAO,KAAKC,cAAc,MAAM,qBAAqB;AAErD;;;AAGA,OAAO,KAAKC,gBAAgB,MAAM,uBAAuB;AAEzD;;;AAGA,OAAO,KAAKC,cAAc,MAAM,qBAAqB;AAErD;;;AAGA,OAAO,KAAKC,qBAAqB,MAAM,4BAA4B;AAEnE;;;AAGA,OAAO,KAAKC,iBAAiB,MAAM,wBAAwB;AAE3D;;;AAGA,OAAO,KAAKC,aAAa,MAAM,oBAAoB;AAEnD;;;AAGA,OAAO,KAAKC,QAAQ,MAAM,eAAe;AAEzC;;;AAGA,OAAO,KAAKC,WAAW,MAAM,kBAAkB;AAE/C;;;AAGA,OAAO,KAAKC,QAAQ,MAAM,eAAe;AAEzC;;;AAGA,OAAO,KAAKC,UAAU,MAAM,iBAAiB;AAE7C;;;AAGA,OAAO,KAAKC,UAAU,MAAM,iBAAiB;AAE7C;;;AAGA,OAAO,KAAKC,YAAY,MAAM,mBAAmB;AAEjD;;;AAGA,OAAO,KAAKC,UAAU,MAAM,iBAAiB;AAE7C;;;AAGA,OAAO,KAAKC,gBAAgB,MAAM,uBAAuB;AAEzD;;;AAGA,OAAO,KAAKC,MAAM,MAAM,aAAa","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"index.js","names":["NodeClusterRunnerHttp","NodeClusterRunnerSocket","NodeClusterShardManagerHttp","NodeClusterShardManagerSocket","NodeCommandExecutor","NodeContext","NodeFileSystem","NodeHttpClient","NodeHttpPlatform","NodeHttpServer","NodeHttpServerRequest","NodeKeyValueStore","NodeMultipart","NodePath","NodeRuntime","NodeSink","NodeSocket","NodeSocketServer","NodeStream","NodeTerminal","NodeWorker","NodeWorkerRunner","Undici"],"sources":["../../src/index.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAGA,OAAO,KAAKA,qBAAqB,MAAM,4BAA4B;AAEnE;;;AAGA,OAAO,KAAKC,uBAAuB,MAAM,8BAA8B;AAEvE;;;AAGA,OAAO,KAAKC,2BAA2B,MAAM,kCAAkC;AAE/E;;;AAGA,OAAO,KAAKC,6BAA6B,MAAM,oCAAoC;AAEnF;;;AAGA,OAAO,KAAKC,mBAAmB,MAAM,0BAA0B;AAE/D;;;AAGA,OAAO,KAAKC,WAAW,MAAM,kBAAkB;AAE/C;;;AAGA,OAAO,KAAKC,cAAc,MAAM,qBAAqB;AAErD;;;AAGA,OAAO,KAAKC,cAAc,MAAM,qBAAqB;AAErD;;;AAGA,OAAO,KAAKC,gBAAgB,MAAM,uBAAuB;AAEzD;;;AAGA,OAAO,KAAKC,cAAc,MAAM,qBAAqB;AAErD;;;AAGA,OAAO,KAAKC,qBAAqB,MAAM,4BAA4B;AAEnE;;;AAGA,OAAO,KAAKC,iBAAiB,MAAM,wBAAwB;AAE3D;;;AAGA,OAAO,KAAKC,aAAa,MAAM,oBAAoB;AAEnD;;;AAGA,OAAO,KAAKC,QAAQ,MAAM,eAAe;AAEzC;;;AAGA,OAAO,KAAKC,WAAW,MAAM,kBAAkB;AAE/C;;;AAGA,OAAO,KAAKC,QAAQ,MAAM,eAAe;AAEzC;;;AAGA,OAAO,KAAKC,UAAU,MAAM,iBAAiB;AAE7C;;;AAGA,OAAO,KAAKC,gBAAgB,MAAM,uBAAuB;AAEzD;;;AAGA,OAAO,KAAKC,UAAU,MAAM,iBAAiB;AAE7C;;;AAGA,OAAO,KAAKC,YAAY,MAAM,mBAAmB;AAEjD;;;AAGA,OAAO,KAAKC,UAAU,MAAM,iBAAiB;AAE7C;;;AAGA,OAAO,KAAKC,gBAAgB,MAAM,uBAAuB;AAEzD;;;AAGA,OAAO,KAAKC,MAAM,MAAM,aAAa","ignoreList":[]}
|
|
@@ -55,4 +55,6 @@ export const layerWorker = /*#__PURE__*/Layer.succeed(Worker.PlatformWorker, pla
|
|
|
55
55
|
export const layerManager = /*#__PURE__*/Layer.provide(Worker.layerManager, layerWorker);
|
|
56
56
|
/** @internal */
|
|
57
57
|
export const layer = spawn => Layer.merge(layerManager, Worker.layerSpawner(spawn));
|
|
58
|
+
/** @internal */
|
|
59
|
+
export const layerPlatform = spawn => Layer.merge(layerWorker, Worker.layerSpawner(spawn));
|
|
58
60
|
//# sourceMappingURL=worker.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker.js","names":["Worker","WorkerError","Deferred","Effect","Exit","Layer","Scope","platformWorkerImpl","makePlatform","setup","scope","worker","flatMap","make","exitDeferred","on","unsafeDone","void","as","addFinalizer","suspend","postMessage","await","pipe","interruptible","timeout","catchAllCause","sync","terminate","listen","deferred","emit","port","message","cause","reason","code","Error","layerWorker","succeed","PlatformWorker","layerManager","provide","layer","spawn","merge","layerSpawner"],"sources":["../../../src/internal/worker.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"worker.js","names":["Worker","WorkerError","Deferred","Effect","Exit","Layer","Scope","platformWorkerImpl","makePlatform","setup","scope","worker","flatMap","make","exitDeferred","on","unsafeDone","void","as","addFinalizer","suspend","postMessage","await","pipe","interruptible","timeout","catchAllCause","sync","terminate","listen","deferred","emit","port","message","cause","reason","code","Error","layerWorker","succeed","PlatformWorker","layerManager","provide","layer","spawn","merge","layerSpawner","layerPlatform"],"sources":["../../../src/internal/worker.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -33,9 +33,12 @@ const platformRunnerImpl = /*#__PURE__*/Runner.PlatformRunner.of({
|
|
|
33
33
|
};
|
|
34
34
|
port.on("message", message => {
|
|
35
35
|
if (message[0] === 0) {
|
|
36
|
-
const
|
|
37
|
-
|
|
38
|
-
|
|
36
|
+
const result = handler(0, message[1]);
|
|
37
|
+
if (Effect.isEffect(result)) {
|
|
38
|
+
const fiber = runFork(result);
|
|
39
|
+
fiber.addObserver(onExit);
|
|
40
|
+
FiberSet.unsafeAdd(fiberSet, fiber);
|
|
41
|
+
}
|
|
39
42
|
} else {
|
|
40
43
|
port.close();
|
|
41
44
|
Deferred.unsafeDone(closeLatch, Exit.void);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workerRunner.js","names":["WorkerError","Runner","Cause","Context","Deferred","Effect","Exit","FiberSet","Layer","Runtime","Scope","WorkerThreads","platformRunnerImpl","PlatformRunner","of","PlatformRunnerTypeId","start","closeLatch","gen","parentPort","reason","cause","Error","port","send","_portId","message","transfers","sync","postMessage","run","fnUntraced","handler","runtime","interruptible","pipe","updateContext","omit","fiberSet","make","runFork","onExit","exit","_tag","isInterruptedOnly","unsafeDone","die","squash","on","fiber","addObserver","unsafeAdd","close","void","layer","succeed"],"sources":["../../../src/internal/workerRunner.ts"],"sourcesContent":[null],"mappings":"AAAA,SAASA,WAAW,QAAQ,8BAA8B;AAC1D,OAAO,KAAKC,MAAM,MAAM,+BAA+B;AACvD,OAAO,KAAKC,KAAK,MAAM,cAAc;AACrC,OAAO,KAAKC,OAAO,MAAM,gBAAgB;AACzC,OAAO,KAAKC,QAAQ,MAAM,iBAAiB;AAC3C,OAAO,KAAKC,MAAM,MAAM,eAAe;AACvC,OAAO,KAAKC,IAAI,MAAM,aAAa;AACnC,OAAO,KAAKC,QAAQ,MAAM,iBAAiB;AAC3C,OAAO,KAAKC,KAAK,MAAM,cAAc;AACrC,OAAO,KAAKC,OAAO,MAAM,gBAAgB;AACzC,OAAO,KAAKC,KAAK,MAAM,cAAc;AACrC,OAAO,KAAKC,aAAa,MAAM,qBAAqB;AAEpD,MAAMC,kBAAkB,gBAAGX,MAAM,CAACY,cAAc,CAACC,EAAE,CAAC;EAClD,CAACb,MAAM,CAACc,oBAAoB,GAAGd,MAAM,CAACc,oBAAoB;EAC1DC,KAAKA,CAAOC,UAAgD;IAC1D,OAAOZ,MAAM,CAACa,GAAG,CAAC,aAAS;MACzB,IAAI,CAACP,aAAa,CAACQ,UAAU,EAAE;QAC7B,OAAO,OAAO,IAAInB,WAAW,CAAC;UAAEoB,MAAM,EAAE,OAAO;UAAEC,KAAK,EAAE,IAAIC,KAAK,CAAC,wBAAwB;QAAC,CAAE,CAAC;MAChG;MACA,MAAMC,IAAI,GAAGZ,aAAa,CAACQ,UAAU;MACrC,MAAMK,IAAI,GAAGA,CAACC,OAAe,EAAEC,OAAU,EAAEC,SAAkC,KAC3EtB,MAAM,CAACuB,IAAI,CAAC,MAAML,IAAI,CAACM,WAAW,CAAC,CAAC,CAAC,EAAEH,OAAO,CAAC,EAAEC,SAAgB,CAAC,CAAC;MAErE,MAAMG,GAAG,GAAGzB,MAAM,CAAC0B,UAAU,CAAC,WAC5BC,
|
|
1
|
+
{"version":3,"file":"workerRunner.js","names":["WorkerError","Runner","Cause","Context","Deferred","Effect","Exit","FiberSet","Layer","Runtime","Scope","WorkerThreads","platformRunnerImpl","PlatformRunner","of","PlatformRunnerTypeId","start","closeLatch","gen","parentPort","reason","cause","Error","port","send","_portId","message","transfers","sync","postMessage","run","fnUntraced","handler","runtime","interruptible","pipe","updateContext","omit","fiberSet","make","runFork","onExit","exit","_tag","isInterruptedOnly","unsafeDone","die","squash","on","result","isEffect","fiber","addObserver","unsafeAdd","close","void","layer","succeed"],"sources":["../../../src/internal/workerRunner.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@effect/platform-node",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.76.0",
|
|
4
4
|
"description": "Platform specific implementations for the Node.js runtime",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"repository": {
|
|
@@ -13,11 +13,14 @@
|
|
|
13
13
|
"mime": "^3.0.0",
|
|
14
14
|
"undici": "^7.1.0",
|
|
15
15
|
"ws": "^8.18.0",
|
|
16
|
-
"@effect/platform-node-shared": "^0.
|
|
16
|
+
"@effect/platform-node-shared": "^0.30.0"
|
|
17
17
|
},
|
|
18
18
|
"peerDependencies": {
|
|
19
|
-
"@effect/
|
|
20
|
-
"effect": "^
|
|
19
|
+
"@effect/cluster": "^0.29.0",
|
|
20
|
+
"@effect/platform": "^0.80.0",
|
|
21
|
+
"@effect/rpc": "^0.55.0",
|
|
22
|
+
"@effect/sql": "^0.33.0",
|
|
23
|
+
"effect": "^3.14.0"
|
|
21
24
|
},
|
|
22
25
|
"publishConfig": {
|
|
23
26
|
"provenance": true
|
|
@@ -32,6 +35,26 @@
|
|
|
32
35
|
"import": "./dist/esm/index.js",
|
|
33
36
|
"default": "./dist/cjs/index.js"
|
|
34
37
|
},
|
|
38
|
+
"./NodeClusterRunnerHttp": {
|
|
39
|
+
"types": "./dist/dts/NodeClusterRunnerHttp.d.ts",
|
|
40
|
+
"import": "./dist/esm/NodeClusterRunnerHttp.js",
|
|
41
|
+
"default": "./dist/cjs/NodeClusterRunnerHttp.js"
|
|
42
|
+
},
|
|
43
|
+
"./NodeClusterRunnerSocket": {
|
|
44
|
+
"types": "./dist/dts/NodeClusterRunnerSocket.d.ts",
|
|
45
|
+
"import": "./dist/esm/NodeClusterRunnerSocket.js",
|
|
46
|
+
"default": "./dist/cjs/NodeClusterRunnerSocket.js"
|
|
47
|
+
},
|
|
48
|
+
"./NodeClusterShardManagerHttp": {
|
|
49
|
+
"types": "./dist/dts/NodeClusterShardManagerHttp.d.ts",
|
|
50
|
+
"import": "./dist/esm/NodeClusterShardManagerHttp.js",
|
|
51
|
+
"default": "./dist/cjs/NodeClusterShardManagerHttp.js"
|
|
52
|
+
},
|
|
53
|
+
"./NodeClusterShardManagerSocket": {
|
|
54
|
+
"types": "./dist/dts/NodeClusterShardManagerSocket.d.ts",
|
|
55
|
+
"import": "./dist/esm/NodeClusterShardManagerSocket.js",
|
|
56
|
+
"default": "./dist/cjs/NodeClusterShardManagerSocket.js"
|
|
57
|
+
},
|
|
35
58
|
"./NodeCommandExecutor": {
|
|
36
59
|
"types": "./dist/dts/NodeCommandExecutor.d.ts",
|
|
37
60
|
"import": "./dist/esm/NodeCommandExecutor.js",
|
|
@@ -102,6 +125,11 @@
|
|
|
102
125
|
"import": "./dist/esm/NodeSocket.js",
|
|
103
126
|
"default": "./dist/cjs/NodeSocket.js"
|
|
104
127
|
},
|
|
128
|
+
"./NodeSocketServer": {
|
|
129
|
+
"types": "./dist/dts/NodeSocketServer.d.ts",
|
|
130
|
+
"import": "./dist/esm/NodeSocketServer.js",
|
|
131
|
+
"default": "./dist/cjs/NodeSocketServer.js"
|
|
132
|
+
},
|
|
105
133
|
"./NodeStream": {
|
|
106
134
|
"types": "./dist/dts/NodeStream.d.ts",
|
|
107
135
|
"import": "./dist/esm/NodeStream.js",
|
|
@@ -130,6 +158,18 @@
|
|
|
130
158
|
},
|
|
131
159
|
"typesVersions": {
|
|
132
160
|
"*": {
|
|
161
|
+
"NodeClusterRunnerHttp": [
|
|
162
|
+
"./dist/dts/NodeClusterRunnerHttp.d.ts"
|
|
163
|
+
],
|
|
164
|
+
"NodeClusterRunnerSocket": [
|
|
165
|
+
"./dist/dts/NodeClusterRunnerSocket.d.ts"
|
|
166
|
+
],
|
|
167
|
+
"NodeClusterShardManagerHttp": [
|
|
168
|
+
"./dist/dts/NodeClusterShardManagerHttp.d.ts"
|
|
169
|
+
],
|
|
170
|
+
"NodeClusterShardManagerSocket": [
|
|
171
|
+
"./dist/dts/NodeClusterShardManagerSocket.d.ts"
|
|
172
|
+
],
|
|
133
173
|
"NodeCommandExecutor": [
|
|
134
174
|
"./dist/dts/NodeCommandExecutor.d.ts"
|
|
135
175
|
],
|
|
@@ -172,6 +212,9 @@
|
|
|
172
212
|
"NodeSocket": [
|
|
173
213
|
"./dist/dts/NodeSocket.d.ts"
|
|
174
214
|
],
|
|
215
|
+
"NodeSocketServer": [
|
|
216
|
+
"./dist/dts/NodeSocketServer.d.ts"
|
|
217
|
+
],
|
|
175
218
|
"NodeStream": [
|
|
176
219
|
"./dist/dts/NodeStream.d.ts"
|
|
177
220
|
],
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @since 1.0.0
|
|
3
|
+
*/
|
|
4
|
+
import * as HttpRunner from "@effect/cluster/HttpRunner"
|
|
5
|
+
import * as MessageStorage from "@effect/cluster/MessageStorage"
|
|
6
|
+
import type * as Runners from "@effect/cluster/Runners"
|
|
7
|
+
import type { Sharding } from "@effect/cluster/Sharding"
|
|
8
|
+
import * as ShardingConfig from "@effect/cluster/ShardingConfig"
|
|
9
|
+
import * as ShardStorage from "@effect/cluster/ShardStorage"
|
|
10
|
+
import * as SqlMessageStorage from "@effect/cluster/SqlMessageStorage"
|
|
11
|
+
import * as SqlShardStorage from "@effect/cluster/SqlShardStorage"
|
|
12
|
+
import type * as Etag from "@effect/platform/Etag"
|
|
13
|
+
import type { HttpPlatform } from "@effect/platform/HttpPlatform"
|
|
14
|
+
import type { HttpServer } from "@effect/platform/HttpServer"
|
|
15
|
+
import type { ServeError } from "@effect/platform/HttpServerError"
|
|
16
|
+
import * as RpcSerialization from "@effect/rpc/RpcSerialization"
|
|
17
|
+
import type { SqlClient } from "@effect/sql/SqlClient"
|
|
18
|
+
import type { SqlError } from "@effect/sql/SqlError"
|
|
19
|
+
import type { ConfigError } from "effect/ConfigError"
|
|
20
|
+
import * as Effect from "effect/Effect"
|
|
21
|
+
import * as Layer from "effect/Layer"
|
|
22
|
+
import * as Option from "effect/Option"
|
|
23
|
+
import { createServer } from "node:http"
|
|
24
|
+
import type { NodeContext } from "./NodeContext.js"
|
|
25
|
+
import * as NodeHttpClient from "./NodeHttpClient.js"
|
|
26
|
+
import * as NodeHttpServer from "./NodeHttpServer.js"
|
|
27
|
+
import * as NodeSocket from "./NodeSocket.js"
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* @since 1.0.0
|
|
31
|
+
* @category Layers
|
|
32
|
+
*/
|
|
33
|
+
export const layer = <
|
|
34
|
+
const ClientOnly extends boolean = false,
|
|
35
|
+
const Storage extends "noop" | "sql" = "noop"
|
|
36
|
+
>(options: {
|
|
37
|
+
readonly transport: "http" | "websocket"
|
|
38
|
+
readonly serialization?: "msgpack" | "ndjson" | undefined
|
|
39
|
+
readonly clientOnly?: ClientOnly | undefined
|
|
40
|
+
readonly storage?: Storage | undefined
|
|
41
|
+
readonly shardingConfig?: Partial<ShardingConfig.ShardingConfig["Type"]> | undefined
|
|
42
|
+
}): ClientOnly extends true ? Layer.Layer<
|
|
43
|
+
Sharding | Runners.Runners,
|
|
44
|
+
ConfigError | (Storage extends "sql" ? SqlError : never),
|
|
45
|
+
Storage extends "sql" ? SqlClient : never
|
|
46
|
+
> :
|
|
47
|
+
Layer.Layer<
|
|
48
|
+
Sharding | Runners.Runners,
|
|
49
|
+
ServeError | ConfigError | (Storage extends "sql" ? SqlError : never),
|
|
50
|
+
Storage extends "sql" ? SqlClient : never
|
|
51
|
+
> =>
|
|
52
|
+
{
|
|
53
|
+
const layer: Layer.Layer<any, any, any> = options.clientOnly
|
|
54
|
+
// client only
|
|
55
|
+
? options.transport === "http"
|
|
56
|
+
? Layer.provide(HttpRunner.layerHttpClientOnly, NodeHttpClient.layerUndici)
|
|
57
|
+
: Layer.provide(HttpRunner.layerWebsocketClientOnly, NodeSocket.layerWebSocketConstructor)
|
|
58
|
+
// with server
|
|
59
|
+
: options.transport === "http"
|
|
60
|
+
? Layer.provide(HttpRunner.layerHttp, [layerHttpServer, NodeHttpClient.layerUndici])
|
|
61
|
+
: Layer.provide(HttpRunner.layerWebsocket, [layerHttpServer, NodeSocket.layerWebSocketConstructor])
|
|
62
|
+
|
|
63
|
+
return layer.pipe(
|
|
64
|
+
Layer.provide(
|
|
65
|
+
options?.storage === "sql"
|
|
66
|
+
? options.clientOnly ? [SqlMessageStorage.layer] : [SqlMessageStorage.layer, SqlShardStorage.layer]
|
|
67
|
+
: [MessageStorage.layerNoop, ShardStorage.layerNoop]
|
|
68
|
+
),
|
|
69
|
+
Layer.provide(ShardingConfig.layerFromEnv(options?.shardingConfig)),
|
|
70
|
+
Layer.provide(
|
|
71
|
+
options?.serialization === "ndjson" ? RpcSerialization.layerNdjson : RpcSerialization.layerMsgPack
|
|
72
|
+
)
|
|
73
|
+
) as any
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
/**
|
|
77
|
+
* @since 1.0.0
|
|
78
|
+
* @category Layers
|
|
79
|
+
*/
|
|
80
|
+
export const layerHttpServer: Layer.Layer<
|
|
81
|
+
| HttpPlatform
|
|
82
|
+
| Etag.Generator
|
|
83
|
+
| NodeContext
|
|
84
|
+
| HttpServer,
|
|
85
|
+
ServeError,
|
|
86
|
+
ShardingConfig.ShardingConfig
|
|
87
|
+
> = Effect.gen(function*() {
|
|
88
|
+
const config = yield* ShardingConfig.ShardingConfig
|
|
89
|
+
if (Option.isNone(config.runnerAddress)) {
|
|
90
|
+
return yield* Effect.dieMessage("NodeClusterHttpRunner.layerHttpServer: ShardingConfig.podAddress is None")
|
|
91
|
+
}
|
|
92
|
+
return NodeHttpServer.layer(createServer, config.runnerAddress.value)
|
|
93
|
+
}).pipe(Layer.unwrapEffect)
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @since 1.0.0
|
|
3
|
+
*/
|
|
4
|
+
import * as HttpShardManager from "@effect/cluster/HttpShardManager"
|
|
5
|
+
import * as ShardingConfig from "@effect/cluster/ShardingConfig"
|
|
6
|
+
import * as ShardManager from "@effect/cluster/ShardManager"
|
|
7
|
+
import * as ShardStorage from "@effect/cluster/ShardStorage"
|
|
8
|
+
import * as SqlShardStorage from "@effect/cluster/SqlShardStorage"
|
|
9
|
+
import type * as Etag from "@effect/platform/Etag"
|
|
10
|
+
import type { HttpPlatform } from "@effect/platform/HttpPlatform"
|
|
11
|
+
import type { HttpServer } from "@effect/platform/HttpServer"
|
|
12
|
+
import type { ServeError } from "@effect/platform/HttpServerError"
|
|
13
|
+
import * as RpcSerialization from "@effect/rpc/RpcSerialization"
|
|
14
|
+
import type { SqlClient } from "@effect/sql/SqlClient"
|
|
15
|
+
import type { SqlError } from "@effect/sql/SqlError"
|
|
16
|
+
import type { ConfigError } from "effect/ConfigError"
|
|
17
|
+
import * as Effect from "effect/Effect"
|
|
18
|
+
import * as Layer from "effect/Layer"
|
|
19
|
+
import { createServer } from "node:http"
|
|
20
|
+
import type { NodeContext } from "./NodeContext.js"
|
|
21
|
+
import * as NodeHttpClient from "./NodeHttpClient.js"
|
|
22
|
+
import * as NodeHttpServer from "./NodeHttpServer.js"
|
|
23
|
+
import * as NodeSocket from "./NodeSocket.js"
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* @since 1.0.0
|
|
27
|
+
* @category Layers
|
|
28
|
+
*/
|
|
29
|
+
export const layerHttpServer: Layer.Layer<
|
|
30
|
+
| HttpPlatform
|
|
31
|
+
| Etag.Generator
|
|
32
|
+
| NodeContext
|
|
33
|
+
| HttpServer,
|
|
34
|
+
ServeError,
|
|
35
|
+
ShardingConfig.ShardingConfig
|
|
36
|
+
> = Effect.gen(function*() {
|
|
37
|
+
const config = yield* ShardingConfig.ShardingConfig
|
|
38
|
+
return NodeHttpServer.layer(createServer, config.shardManagerAddress)
|
|
39
|
+
}).pipe(Layer.unwrapEffect)
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* @since 1.0.0
|
|
43
|
+
* @category Layers
|
|
44
|
+
*/
|
|
45
|
+
export const layer = <const Storage extends "sql" | "noop" = "noop">(options: {
|
|
46
|
+
readonly protocol: "http" | "websocket"
|
|
47
|
+
readonly serialization?: "msgpack" | "ndjson" | undefined
|
|
48
|
+
readonly shardingConfig?: Partial<ShardingConfig.ShardingConfig["Type"]> | undefined
|
|
49
|
+
readonly storage?: Storage | undefined
|
|
50
|
+
}): Layer.Layer<
|
|
51
|
+
ShardManager.ShardManager,
|
|
52
|
+
ServeError | ConfigError | (Storage extends "sql" ? SqlError : never),
|
|
53
|
+
Storage extends "sql" ? SqlClient : never
|
|
54
|
+
> => {
|
|
55
|
+
const layer: Layer.Layer<any, any, any> = options.protocol === "http" ?
|
|
56
|
+
HttpShardManager.layerHttp.pipe(
|
|
57
|
+
Layer.provide([HttpShardManager.layerRunnerHealthHttp, layerHttpServer]),
|
|
58
|
+
Layer.provide(NodeHttpClient.layerUndici)
|
|
59
|
+
) :
|
|
60
|
+
HttpShardManager.layerWebsocket.pipe(
|
|
61
|
+
Layer.provide([HttpShardManager.layerRunnerHealthWebsocket, layerHttpServer]),
|
|
62
|
+
Layer.provide(NodeSocket.layerWebSocketConstructor)
|
|
63
|
+
)
|
|
64
|
+
return layer.pipe(
|
|
65
|
+
Layer.provide(options?.storage === "sql" ? SqlShardStorage.layer : ShardStorage.layerNoop),
|
|
66
|
+
Layer.provide([
|
|
67
|
+
ShardingConfig.layerFromEnv(options.shardingConfig),
|
|
68
|
+
ShardManager.layerConfigFromEnv,
|
|
69
|
+
options?.serialization === "ndjson" ? RpcSerialization.layerNdjson : RpcSerialization.layerMsgPack
|
|
70
|
+
])
|
|
71
|
+
)
|
|
72
|
+
}
|
package/src/NodeWorker.ts
CHANGED
|
@@ -24,4 +24,12 @@ export const layerWorker: Layer.Layer<Worker.PlatformWorker> = internal.layerWor
|
|
|
24
24
|
*/
|
|
25
25
|
export const layer: (
|
|
26
26
|
spawn: (id: number) => WorkerThreads.Worker
|
|
27
|
-
) => Layer.Layer<Worker.WorkerManager | Worker.Spawner
|
|
27
|
+
) => Layer.Layer<Worker.WorkerManager | Worker.Spawner> = internal.layer
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* @since 1.0.0
|
|
31
|
+
* @category layers
|
|
32
|
+
*/
|
|
33
|
+
export const layerPlatform: (
|
|
34
|
+
spawn: (id: number) => WorkerThreads.Worker
|
|
35
|
+
) => Layer.Layer<Worker.PlatformWorker | Worker.Spawner> = internal.layerPlatform
|
package/src/index.ts
CHANGED
|
@@ -1,3 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @since 1.0.0
|
|
3
|
+
*/
|
|
4
|
+
export * as NodeClusterRunnerHttp from "./NodeClusterRunnerHttp.js"
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* @since 1.0.0
|
|
8
|
+
*/
|
|
9
|
+
export * as NodeClusterRunnerSocket from "./NodeClusterRunnerSocket.js"
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* @since 1.0.0
|
|
13
|
+
*/
|
|
14
|
+
export * as NodeClusterShardManagerHttp from "./NodeClusterShardManagerHttp.js"
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* @since 1.0.0
|
|
18
|
+
*/
|
|
19
|
+
export * as NodeClusterShardManagerSocket from "./NodeClusterShardManagerSocket.js"
|
|
20
|
+
|
|
1
21
|
/**
|
|
2
22
|
* @since 1.0.0
|
|
3
23
|
*/
|
|
@@ -63,6 +83,11 @@ export * as NodeSink from "./NodeSink.js"
|
|
|
63
83
|
*/
|
|
64
84
|
export * as NodeSocket from "./NodeSocket.js"
|
|
65
85
|
|
|
86
|
+
/**
|
|
87
|
+
* @since 1.0.0
|
|
88
|
+
*/
|
|
89
|
+
export * as NodeSocketServer from "./NodeSocketServer.js"
|
|
90
|
+
|
|
66
91
|
/**
|
|
67
92
|
* @since 1.0.0
|
|
68
93
|
*/
|
package/src/internal/worker.ts
CHANGED
|
@@ -64,3 +64,7 @@ export const layer = (spawn: (id: number) => WorkerThreads.Worker) =>
|
|
|
64
64
|
layerManager,
|
|
65
65
|
Worker.layerSpawner(spawn)
|
|
66
66
|
)
|
|
67
|
+
|
|
68
|
+
/** @internal */
|
|
69
|
+
export const layerPlatform = (spawn: (id: number) => WorkerThreads.Worker) =>
|
|
70
|
+
Layer.merge(layerWorker, Worker.layerSpawner(spawn))
|
|
@@ -23,7 +23,7 @@ const platformRunnerImpl = Runner.PlatformRunner.of({
|
|
|
23
23
|
Effect.sync(() => port.postMessage([1, message], transfers as any))
|
|
24
24
|
|
|
25
25
|
const run = Effect.fnUntraced(function*<A, E, R>(
|
|
26
|
-
handler: (portId: number, message: I) => Effect.Effect<A, E, R>
|
|
26
|
+
handler: (portId: number, message: I) => Effect.Effect<A, E, R> | void
|
|
27
27
|
) {
|
|
28
28
|
const runtime = (yield* Effect.interruptible(Effect.runtime<R | Scope.Scope>())).pipe(
|
|
29
29
|
Runtime.updateContext(Context.omit(Scope.Scope))
|
|
@@ -37,9 +37,12 @@ const platformRunnerImpl = Runner.PlatformRunner.of({
|
|
|
37
37
|
}
|
|
38
38
|
port.on("message", (message: Runner.BackingRunner.Message<I>) => {
|
|
39
39
|
if (message[0] === 0) {
|
|
40
|
-
const
|
|
41
|
-
|
|
42
|
-
|
|
40
|
+
const result = handler(0, message[1])
|
|
41
|
+
if (Effect.isEffect(result)) {
|
|
42
|
+
const fiber = runFork(result)
|
|
43
|
+
fiber.addObserver(onExit)
|
|
44
|
+
FiberSet.unsafeAdd(fiberSet, fiber)
|
|
45
|
+
}
|
|
43
46
|
} else {
|
|
44
47
|
port.close()
|
|
45
48
|
Deferred.unsafeDone(closeLatch, Exit.void)
|