@effect/platform-node 0.75.3 → 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.
Files changed (64) hide show
  1. package/NodeClusterRunnerHttp/package.json +6 -0
  2. package/NodeClusterRunnerSocket/package.json +6 -0
  3. package/NodeClusterShardManagerHttp/package.json +6 -0
  4. package/NodeClusterShardManagerSocket/package.json +6 -0
  5. package/NodeSocketServer/package.json +6 -0
  6. package/dist/cjs/NodeClusterRunnerHttp.js +51 -0
  7. package/dist/cjs/NodeClusterRunnerHttp.js.map +1 -0
  8. package/dist/cjs/NodeClusterRunnerSocket.js +17 -0
  9. package/dist/cjs/NodeClusterRunnerSocket.js.map +1 -0
  10. package/dist/cjs/NodeClusterShardManagerHttp.js +42 -0
  11. package/dist/cjs/NodeClusterShardManagerHttp.js.map +1 -0
  12. package/dist/cjs/NodeClusterShardManagerSocket.js +17 -0
  13. package/dist/cjs/NodeClusterShardManagerSocket.js.map +1 -0
  14. package/dist/cjs/NodeSocketServer.js +17 -0
  15. package/dist/cjs/NodeSocketServer.js.map +1 -0
  16. package/dist/cjs/NodeWorker.js +6 -1
  17. package/dist/cjs/NodeWorker.js.map +1 -1
  18. package/dist/cjs/index.js +11 -1
  19. package/dist/cjs/internal/worker.js +4 -1
  20. package/dist/cjs/internal/worker.js.map +1 -1
  21. package/dist/cjs/internal/workerRunner.js +6 -3
  22. package/dist/cjs/internal/workerRunner.js.map +1 -1
  23. package/dist/dts/NodeClusterRunnerHttp.d.ts +29 -0
  24. package/dist/dts/NodeClusterRunnerHttp.d.ts.map +1 -0
  25. package/dist/dts/NodeClusterRunnerSocket.d.ts +9 -0
  26. package/dist/dts/NodeClusterRunnerSocket.d.ts.map +1 -0
  27. package/dist/dts/NodeClusterShardManagerHttp.d.ts +27 -0
  28. package/dist/dts/NodeClusterShardManagerHttp.d.ts.map +1 -0
  29. package/dist/dts/NodeClusterShardManagerSocket.d.ts +9 -0
  30. package/dist/dts/NodeClusterShardManagerSocket.d.ts.map +1 -0
  31. package/dist/dts/NodeSocketServer.d.ts +8 -0
  32. package/dist/dts/NodeSocketServer.d.ts.map +1 -0
  33. package/dist/dts/NodeWorker.d.ts +6 -1
  34. package/dist/dts/NodeWorker.d.ts.map +1 -1
  35. package/dist/dts/index.d.ts +20 -0
  36. package/dist/dts/index.d.ts.map +1 -1
  37. package/dist/esm/NodeClusterRunnerHttp.js +41 -0
  38. package/dist/esm/NodeClusterRunnerHttp.js.map +1 -0
  39. package/dist/esm/NodeClusterRunnerSocket.js +9 -0
  40. package/dist/esm/NodeClusterRunnerSocket.js.map +1 -0
  41. package/dist/esm/NodeClusterShardManagerHttp.js +32 -0
  42. package/dist/esm/NodeClusterShardManagerHttp.js.map +1 -0
  43. package/dist/esm/NodeClusterShardManagerSocket.js +9 -0
  44. package/dist/esm/NodeClusterShardManagerSocket.js.map +1 -0
  45. package/dist/esm/NodeSocketServer.js +8 -0
  46. package/dist/esm/NodeSocketServer.js.map +1 -0
  47. package/dist/esm/NodeWorker.js +5 -0
  48. package/dist/esm/NodeWorker.js.map +1 -1
  49. package/dist/esm/index.js +20 -0
  50. package/dist/esm/index.js.map +1 -1
  51. package/dist/esm/internal/worker.js +2 -0
  52. package/dist/esm/internal/worker.js.map +1 -1
  53. package/dist/esm/internal/workerRunner.js +6 -3
  54. package/dist/esm/internal/workerRunner.js.map +1 -1
  55. package/package.json +47 -4
  56. package/src/NodeClusterRunnerHttp.ts +93 -0
  57. package/src/NodeClusterRunnerSocket.ts +9 -0
  58. package/src/NodeClusterShardManagerHttp.ts +72 -0
  59. package/src/NodeClusterShardManagerSocket.ts +9 -0
  60. package/src/NodeSocketServer.ts +8 -0
  61. package/src/NodeWorker.ts +9 -1
  62. package/src/index.ts +25 -0
  63. package/src/internal/worker.ts +4 -0
  64. package/src/internal/workerRunner.ts +7 -4
@@ -0,0 +1,9 @@
1
+ /**
2
+ * @since 1.0.0
3
+ */
4
+ /**
5
+ * @since 1.0.0
6
+ * @category Re-exports
7
+ */
8
+ export * from "@effect/platform-node-shared/NodeClusterRunnerSocket";
9
+ //# sourceMappingURL=NodeClusterRunnerSocket.js.map
@@ -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,9 @@
1
+ /**
2
+ * @since 1.0.0
3
+ */
4
+ /**
5
+ * @since 1.0.0
6
+ * @category Re-exports
7
+ */
8
+ export * from "@effect/platform-node-shared/NodeClusterShardManagerSocket";
9
+ //# sourceMappingURL=NodeClusterShardManagerSocket.js.map
@@ -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,8 @@
1
+ /**
2
+ * @since 1.0.0
3
+ */
4
+ /**
5
+ * @since 1.0.0
6
+ */
7
+ export * from "@effect/platform-node-shared/NodeSocketServer";
8
+ //# sourceMappingURL=NodeSocketServer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NodeSocketServer.js","names":[],"sources":["../../src/NodeSocketServer.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAIA;;;AAGA,cAAc,+CAA+C","ignoreList":[]}
@@ -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,GAEsDH,QAAQ,CAACG,KAAK","ignoreList":[]}
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
  */
@@ -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 fiber = runFork(handler(0, message[1]));
37
- fiber.addObserver(onExit);
38
- FiberSet.unsafeAdd(fiberSet, fiber);
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":"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","ignoreList":[]}
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.75.3",
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.29.3"
16
+ "@effect/platform-node-shared": "^0.30.0"
17
17
  },
18
18
  "peerDependencies": {
19
- "@effect/platform": "^0.79.3",
20
- "effect": "^3.13.12"
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,9 @@
1
+ /**
2
+ * @since 1.0.0
3
+ */
4
+
5
+ /**
6
+ * @since 1.0.0
7
+ * @category Re-exports
8
+ */
9
+ export * from "@effect/platform-node-shared/NodeClusterRunnerSocket"
@@ -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
+ }
@@ -0,0 +1,9 @@
1
+ /**
2
+ * @since 1.0.0
3
+ */
4
+
5
+ /**
6
+ * @since 1.0.0
7
+ * @category Re-exports
8
+ */
9
+ export * from "@effect/platform-node-shared/NodeClusterShardManagerSocket"
@@ -0,0 +1,8 @@
1
+ /**
2
+ * @since 1.0.0
3
+ */
4
+
5
+ /**
6
+ * @since 1.0.0
7
+ */
8
+ export * from "@effect/platform-node-shared/NodeSocketServer"
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, never, never> = internal.layer
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
  */
@@ -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 fiber = runFork(handler(0, message[1]))
41
- fiber.addObserver(onExit)
42
- FiberSet.unsafeAdd(fiberSet, fiber)
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)