@effect/platform-node 0.42.10 → 0.43.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 (376) hide show
  1. package/NodeCommandExecutor/package.json +6 -0
  2. package/NodeFileSystem/package.json +6 -0
  3. package/NodeHttpClient/package.json +6 -0
  4. package/NodeHttpServer/package.json +6 -0
  5. package/NodeKeyValueStore/package.json +6 -0
  6. package/NodePath/package.json +6 -0
  7. package/NodeRuntime/package.json +6 -0
  8. package/NodeSink/package.json +6 -0
  9. package/NodeStream/package.json +6 -0
  10. package/NodeTerminal/package.json +6 -0
  11. package/NodeWorker/package.json +6 -0
  12. package/NodeWorkerRunner/package.json +6 -0
  13. package/dist/cjs/Http/Platform.js +0 -20
  14. package/dist/cjs/Http/Platform.js.map +1 -1
  15. package/dist/cjs/Http/Server.js +6 -23
  16. package/dist/cjs/Http/Server.js.map +1 -1
  17. package/dist/cjs/Http/ServerRequest.js +0 -19
  18. package/dist/cjs/Http/ServerRequest.js.map +1 -1
  19. package/dist/cjs/{FileSystem.js → NodeCommandExecutor.js} +3 -16
  20. package/dist/cjs/NodeCommandExecutor.js.map +1 -0
  21. package/dist/cjs/NodeContext.js +6 -6
  22. package/dist/cjs/NodeContext.js.map +1 -1
  23. package/dist/cjs/NodeFileSystem.js +42 -0
  24. package/dist/cjs/NodeFileSystem.js.map +1 -0
  25. package/dist/cjs/{Http/NodeClient.js → NodeHttpClient.js} +2 -2
  26. package/dist/cjs/{Http/NodeClient.js.map → NodeHttpClient.js.map} +1 -1
  27. package/dist/cjs/NodeHttpServer.js +40 -0
  28. package/dist/cjs/NodeHttpServer.js.map +1 -0
  29. package/dist/cjs/NodeKeyValueStore.js +42 -0
  30. package/dist/cjs/NodeKeyValueStore.js.map +1 -0
  31. package/dist/cjs/{Path.js → NodePath.js} +5 -12
  32. package/dist/cjs/NodePath.js.map +1 -0
  33. package/dist/cjs/{Runtime.js → NodeRuntime.js} +7 -10
  34. package/dist/cjs/NodeRuntime.js.map +1 -0
  35. package/dist/cjs/NodeSink.js +17 -0
  36. package/dist/cjs/NodeSink.js.map +1 -0
  37. package/dist/cjs/NodeStream.js +17 -0
  38. package/dist/cjs/NodeStream.js.map +1 -0
  39. package/dist/cjs/{Terminal.js → NodeTerminal.js} +8 -11
  40. package/dist/cjs/NodeTerminal.js.map +1 -0
  41. package/dist/cjs/{Sink.js → NodeWorker.js} +9 -8
  42. package/dist/cjs/NodeWorker.js.map +1 -0
  43. package/dist/cjs/{CommandExecutor.js → NodeWorkerRunner.js} +3 -10
  44. package/dist/cjs/NodeWorkerRunner.js.map +1 -0
  45. package/dist/cjs/index.js +25 -33
  46. package/dist/cjs/internal/http/{nodeClient.js → client.js} +3 -3
  47. package/dist/cjs/internal/http/{nodeClient.js.map → client.js.map} +1 -1
  48. package/dist/cjs/internal/http/incomingMessage.js +1 -1
  49. package/dist/cjs/internal/http/incomingMessage.js.map +1 -1
  50. package/dist/cjs/internal/http/platform.js +3 -3
  51. package/dist/cjs/internal/http/platform.js.map +1 -1
  52. package/dist/cjs/internal/http/server.js +13 -8
  53. package/dist/cjs/internal/http/server.js.map +1 -1
  54. package/dist/cjs/internal/worker.js +3 -8
  55. package/dist/cjs/internal/worker.js.map +1 -1
  56. package/dist/cjs/internal/workerRunner.js +2 -8
  57. package/dist/cjs/internal/workerRunner.js.map +1 -1
  58. package/dist/dts/Http/Platform.d.ts +2 -8
  59. package/dist/dts/Http/Platform.d.ts.map +1 -1
  60. package/dist/dts/Http/Server.d.ts +10 -9
  61. package/dist/dts/Http/Server.d.ts.map +1 -1
  62. package/dist/dts/Http/ServerRequest.d.ts +0 -6
  63. package/dist/dts/Http/ServerRequest.d.ts.map +1 -1
  64. package/dist/dts/NodeCommandExecutor.d.ts +9 -0
  65. package/dist/dts/NodeCommandExecutor.d.ts.map +1 -0
  66. package/dist/dts/NodeContext.d.ts +6 -6
  67. package/dist/dts/NodeContext.d.ts.map +1 -1
  68. package/dist/dts/NodeFileSystem.d.ts +8 -0
  69. package/dist/dts/NodeFileSystem.d.ts.map +1 -0
  70. package/dist/dts/{Http/NodeClient.d.ts → NodeHttpClient.d.ts} +7 -7
  71. package/dist/dts/{Http/NodeClient.d.ts.map → NodeHttpClient.d.ts.map} +1 -1
  72. package/dist/dts/NodeHttpServer.d.ts +37 -0
  73. package/dist/dts/NodeHttpServer.d.ts.map +1 -0
  74. package/dist/dts/NodeKeyValueStore.d.ts +9 -0
  75. package/dist/dts/NodeKeyValueStore.d.ts.map +1 -0
  76. package/dist/dts/NodePath.d.ts +21 -0
  77. package/dist/dts/NodePath.d.ts.map +1 -0
  78. package/dist/dts/NodeRuntime.d.ts +7 -0
  79. package/dist/dts/NodeRuntime.d.ts.map +1 -0
  80. package/dist/dts/NodeSink.d.ts +8 -0
  81. package/dist/dts/NodeSink.d.ts.map +1 -0
  82. package/dist/dts/NodeStream.d.ts +8 -0
  83. package/dist/dts/NodeStream.d.ts.map +1 -0
  84. package/dist/dts/NodeTerminal.d.ts +15 -0
  85. package/dist/dts/NodeTerminal.d.ts.map +1 -0
  86. package/dist/dts/NodeWorker.d.ts +23 -0
  87. package/dist/dts/NodeWorker.d.ts.map +1 -0
  88. package/dist/dts/NodeWorkerRunner.d.ts +11 -0
  89. package/dist/dts/NodeWorkerRunner.d.ts.map +1 -0
  90. package/dist/dts/index.d.ts +13 -37
  91. package/dist/dts/index.d.ts.map +1 -1
  92. package/dist/dts/internal/http/client.d.ts +2 -0
  93. package/dist/dts/internal/http/client.d.ts.map +1 -0
  94. package/dist/esm/Http/Platform.js +0 -4
  95. package/dist/esm/Http/Platform.js.map +1 -1
  96. package/dist/esm/Http/Server.js +5 -4
  97. package/dist/esm/Http/Server.js.map +1 -1
  98. package/dist/esm/Http/ServerRequest.js +0 -4
  99. package/dist/esm/Http/ServerRequest.js.map +1 -1
  100. package/dist/esm/NodeCommandExecutor.js +10 -0
  101. package/dist/esm/NodeCommandExecutor.js.map +1 -0
  102. package/dist/esm/NodeContext.js +6 -6
  103. package/dist/esm/NodeContext.js.map +1 -1
  104. package/dist/esm/NodeFileSystem.js +10 -0
  105. package/dist/esm/NodeFileSystem.js.map +1 -0
  106. package/dist/esm/{Http/NodeClient.js → NodeHttpClient.js} +2 -2
  107. package/dist/esm/NodeHttpClient.js.map +1 -0
  108. package/dist/esm/NodeHttpServer.js +37 -0
  109. package/dist/esm/NodeHttpServer.js.map +1 -0
  110. package/dist/esm/NodeKeyValueStore.js +10 -0
  111. package/dist/esm/NodeKeyValueStore.js.map +1 -0
  112. package/dist/esm/NodePath.js +20 -0
  113. package/dist/esm/NodePath.js.map +1 -0
  114. package/dist/esm/NodeRuntime.js +10 -0
  115. package/dist/esm/NodeRuntime.js.map +1 -0
  116. package/dist/esm/NodeSink.js +8 -0
  117. package/dist/esm/NodeSink.js.map +1 -0
  118. package/dist/esm/NodeStream.js +8 -0
  119. package/dist/esm/NodeStream.js.map +1 -0
  120. package/dist/esm/NodeTerminal.js +15 -0
  121. package/dist/esm/NodeTerminal.js.map +1 -0
  122. package/dist/esm/NodeWorker.js +17 -0
  123. package/dist/esm/NodeWorker.js.map +1 -0
  124. package/dist/esm/NodeWorkerRunner.js +7 -0
  125. package/dist/esm/NodeWorkerRunner.js.map +1 -0
  126. package/dist/esm/index.js +13 -37
  127. package/dist/esm/index.js.map +1 -1
  128. package/dist/esm/internal/http/{nodeClient.js → client.js} +3 -3
  129. package/dist/esm/internal/http/client.js.map +1 -0
  130. package/dist/esm/internal/http/incomingMessage.js +1 -1
  131. package/dist/esm/internal/http/incomingMessage.js.map +1 -1
  132. package/dist/esm/internal/http/platform.js +3 -3
  133. package/dist/esm/internal/http/platform.js.map +1 -1
  134. package/dist/esm/internal/http/server.js +11 -7
  135. package/dist/esm/internal/http/server.js.map +1 -1
  136. package/dist/esm/internal/worker.js +1 -7
  137. package/dist/esm/internal/worker.js.map +1 -1
  138. package/dist/esm/internal/workerRunner.js +1 -5
  139. package/dist/esm/internal/workerRunner.js.map +1 -1
  140. package/package.json +89 -145
  141. package/src/Http/Platform.ts +2 -9
  142. package/src/Http/Server.ts +19 -11
  143. package/src/Http/ServerRequest.ts +0 -7
  144. package/src/NodeCommandExecutor.ts +13 -0
  145. package/src/NodeContext.ts +16 -11
  146. package/src/NodeFileSystem.ts +12 -0
  147. package/src/{Http/NodeClient.ts → NodeHttpClient.ts} +7 -8
  148. package/src/NodeHttpServer.ts +38 -0
  149. package/src/NodeKeyValueStore.ts +15 -0
  150. package/src/NodePath.ts +25 -0
  151. package/src/NodeRuntime.ts +11 -0
  152. package/src/NodeSink.ts +8 -0
  153. package/src/NodeStream.ts +8 -0
  154. package/src/NodeTerminal.ts +20 -0
  155. package/src/NodeWorker.ts +27 -0
  156. package/src/NodeWorkerRunner.ts +12 -0
  157. package/src/index.ts +13 -41
  158. package/src/internal/http/{nodeClient.ts → client.ts} +10 -10
  159. package/src/internal/http/incomingMessage.ts +7 -7
  160. package/src/internal/http/platform.ts +3 -3
  161. package/src/internal/http/server.ts +35 -23
  162. package/src/internal/worker.ts +7 -14
  163. package/src/internal/workerRunner.ts +3 -26
  164. package/Command/package.json +0 -6
  165. package/CommandExecutor/package.json +0 -6
  166. package/Effectify/package.json +0 -6
  167. package/Error/package.json +0 -6
  168. package/FileSystem/package.json +0 -6
  169. package/Http/Etag/package.json +0 -6
  170. package/Http/Multipart/package.json +0 -6
  171. package/Http/NodeClient/package.json +0 -6
  172. package/HttpClient/package.json +0 -6
  173. package/HttpServer/package.json +0 -6
  174. package/KeyValueStore/package.json +0 -6
  175. package/Path/package.json +0 -6
  176. package/Runtime/package.json +0 -6
  177. package/Sink/package.json +0 -6
  178. package/Stream/package.json +0 -6
  179. package/Terminal/package.json +0 -6
  180. package/Transferable/package.json +0 -6
  181. package/Worker/package.json +0 -6
  182. package/WorkerRunner/package.json +0 -6
  183. package/dist/cjs/Command.js +0 -109
  184. package/dist/cjs/Command.js.map +0 -1
  185. package/dist/cjs/CommandExecutor.js.map +0 -1
  186. package/dist/cjs/Effectify.js +0 -13
  187. package/dist/cjs/Effectify.js.map +0 -1
  188. package/dist/cjs/Error.js +0 -25
  189. package/dist/cjs/Error.js.map +0 -1
  190. package/dist/cjs/FileSystem.js.map +0 -1
  191. package/dist/cjs/Http/Etag.js +0 -63
  192. package/dist/cjs/Http/Etag.js.map +0 -1
  193. package/dist/cjs/Http/Multipart.js +0 -69
  194. package/dist/cjs/Http/Multipart.js.map +0 -1
  195. package/dist/cjs/HttpClient.js +0 -48
  196. package/dist/cjs/HttpClient.js.map +0 -1
  197. package/dist/cjs/HttpServer.js +0 -58
  198. package/dist/cjs/HttpServer.js.map +0 -1
  199. package/dist/cjs/KeyValueStore.js +0 -60
  200. package/dist/cjs/KeyValueStore.js.map +0 -1
  201. package/dist/cjs/Path.js.map +0 -1
  202. package/dist/cjs/Runtime.js.map +0 -1
  203. package/dist/cjs/Sink.js.map +0 -1
  204. package/dist/cjs/Stream.js +0 -68
  205. package/dist/cjs/Stream.js.map +0 -1
  206. package/dist/cjs/Terminal.js.map +0 -1
  207. package/dist/cjs/Transferable.js +0 -17
  208. package/dist/cjs/Transferable.js.map +0 -1
  209. package/dist/cjs/Worker.js +0 -87
  210. package/dist/cjs/Worker.js.map +0 -1
  211. package/dist/cjs/WorkerRunner.js +0 -69
  212. package/dist/cjs/WorkerRunner.js.map +0 -1
  213. package/dist/cjs/internal/commandExecutor.js +0 -151
  214. package/dist/cjs/internal/commandExecutor.js.map +0 -1
  215. package/dist/cjs/internal/error.js +0 -44
  216. package/dist/cjs/internal/error.js.map +0 -1
  217. package/dist/cjs/internal/fileSystem.js +0 -370
  218. package/dist/cjs/internal/fileSystem.js.map +0 -1
  219. package/dist/cjs/internal/http/etag.js +0 -74
  220. package/dist/cjs/internal/http/etag.js.map +0 -1
  221. package/dist/cjs/internal/http/multipart.js +0 -119
  222. package/dist/cjs/internal/http/multipart.js.map +0 -1
  223. package/dist/cjs/internal/path.js +0 -72
  224. package/dist/cjs/internal/path.js.map +0 -1
  225. package/dist/cjs/internal/runtime.js +0 -59
  226. package/dist/cjs/internal/runtime.js.map +0 -1
  227. package/dist/cjs/internal/sink.js +0 -52
  228. package/dist/cjs/internal/sink.js.map +0 -1
  229. package/dist/cjs/internal/stream.js +0 -208
  230. package/dist/cjs/internal/stream.js.map +0 -1
  231. package/dist/cjs/internal/terminal.js +0 -121
  232. package/dist/cjs/internal/terminal.js.map +0 -1
  233. package/dist/dts/Command.d.ts +0 -116
  234. package/dist/dts/Command.d.ts.map +0 -1
  235. package/dist/dts/CommandExecutor.d.ts +0 -44
  236. package/dist/dts/CommandExecutor.d.ts.map +0 -1
  237. package/dist/dts/Effectify.d.ts +0 -19
  238. package/dist/dts/Effectify.d.ts.map +0 -1
  239. package/dist/dts/Error.d.ts +0 -31
  240. package/dist/dts/Error.d.ts.map +0 -1
  241. package/dist/dts/FileSystem.d.ts +0 -78
  242. package/dist/dts/FileSystem.d.ts.map +0 -1
  243. package/dist/dts/Http/Etag.d.ts +0 -22
  244. package/dist/dts/Http/Etag.d.ts.map +0 -1
  245. package/dist/dts/Http/Multipart.d.ts +0 -35
  246. package/dist/dts/Http/Multipart.d.ts.map +0 -1
  247. package/dist/dts/HttpClient.d.ts +0 -69
  248. package/dist/dts/HttpClient.d.ts.map +0 -1
  249. package/dist/dts/HttpServer.d.ts +0 -109
  250. package/dist/dts/HttpServer.d.ts.map +0 -1
  251. package/dist/dts/KeyValueStore.d.ts +0 -18
  252. package/dist/dts/KeyValueStore.d.ts.map +0 -1
  253. package/dist/dts/Path.d.ts +0 -27
  254. package/dist/dts/Path.d.ts.map +0 -1
  255. package/dist/dts/Runtime.d.ts +0 -27
  256. package/dist/dts/Runtime.d.ts.map +0 -1
  257. package/dist/dts/Sink.d.ts +0 -22
  258. package/dist/dts/Sink.d.ts.map +0 -1
  259. package/dist/dts/Stream.d.ts +0 -79
  260. package/dist/dts/Stream.d.ts.map +0 -1
  261. package/dist/dts/Terminal.d.ts +0 -35
  262. package/dist/dts/Terminal.d.ts.map +0 -1
  263. package/dist/dts/Transferable.d.ts +0 -7
  264. package/dist/dts/Transferable.d.ts.map +0 -1
  265. package/dist/dts/Worker.d.ts +0 -48
  266. package/dist/dts/Worker.d.ts.map +0 -1
  267. package/dist/dts/WorkerRunner.d.ts +0 -30
  268. package/dist/dts/WorkerRunner.d.ts.map +0 -1
  269. package/dist/dts/internal/commandExecutor.d.ts +0 -2
  270. package/dist/dts/internal/commandExecutor.d.ts.map +0 -1
  271. package/dist/dts/internal/error.d.ts +0 -2
  272. package/dist/dts/internal/error.d.ts.map +0 -1
  273. package/dist/dts/internal/fileSystem.d.ts +0 -2
  274. package/dist/dts/internal/fileSystem.d.ts.map +0 -1
  275. package/dist/dts/internal/http/etag.d.ts +0 -2
  276. package/dist/dts/internal/http/etag.d.ts.map +0 -1
  277. package/dist/dts/internal/http/multipart.d.ts +0 -2
  278. package/dist/dts/internal/http/multipart.d.ts.map +0 -1
  279. package/dist/dts/internal/http/nodeClient.d.ts +0 -2
  280. package/dist/dts/internal/http/nodeClient.d.ts.map +0 -1
  281. package/dist/dts/internal/path.d.ts +0 -2
  282. package/dist/dts/internal/path.d.ts.map +0 -1
  283. package/dist/dts/internal/runtime.d.ts +0 -2
  284. package/dist/dts/internal/runtime.d.ts.map +0 -1
  285. package/dist/dts/internal/sink.d.ts +0 -2
  286. package/dist/dts/internal/sink.d.ts.map +0 -1
  287. package/dist/dts/internal/stream.d.ts +0 -2
  288. package/dist/dts/internal/stream.d.ts.map +0 -1
  289. package/dist/dts/internal/terminal.d.ts +0 -2
  290. package/dist/dts/internal/terminal.d.ts.map +0 -1
  291. package/dist/esm/Command.js +0 -90
  292. package/dist/esm/Command.js.map +0 -1
  293. package/dist/esm/CommandExecutor.js +0 -13
  294. package/dist/esm/CommandExecutor.js.map +0 -1
  295. package/dist/esm/Effectify.js +0 -10
  296. package/dist/esm/Effectify.js.map +0 -1
  297. package/dist/esm/Error.js +0 -20
  298. package/dist/esm/Error.js.map +0 -1
  299. package/dist/esm/FileSystem.js +0 -21
  300. package/dist/esm/FileSystem.js.map +0 -1
  301. package/dist/esm/Http/Etag.js +0 -16
  302. package/dist/esm/Http/Etag.js.map +0 -1
  303. package/dist/esm/Http/Multipart.js +0 -21
  304. package/dist/esm/Http/Multipart.js.map +0 -1
  305. package/dist/esm/Http/NodeClient.js.map +0 -1
  306. package/dist/esm/HttpClient.js +0 -69
  307. package/dist/esm/HttpClient.js.map +0 -1
  308. package/dist/esm/HttpServer.js +0 -109
  309. package/dist/esm/HttpServer.js.map +0 -1
  310. package/dist/esm/KeyValueStore.js +0 -14
  311. package/dist/esm/KeyValueStore.js.map +0 -1
  312. package/dist/esm/Path.js +0 -26
  313. package/dist/esm/Path.js.map +0 -1
  314. package/dist/esm/Runtime.js +0 -13
  315. package/dist/esm/Runtime.js.map +0 -1
  316. package/dist/esm/Sink.js +0 -15
  317. package/dist/esm/Sink.js.map +0 -1
  318. package/dist/esm/Stream.js +0 -37
  319. package/dist/esm/Stream.js.map +0 -1
  320. package/dist/esm/Terminal.js +0 -18
  321. package/dist/esm/Terminal.js.map +0 -1
  322. package/dist/esm/Transferable.js +0 -7
  323. package/dist/esm/Transferable.js.map +0 -1
  324. package/dist/esm/Worker.js +0 -36
  325. package/dist/esm/Worker.js.map +0 -1
  326. package/dist/esm/WorkerRunner.js +0 -21
  327. package/dist/esm/WorkerRunner.js.map +0 -1
  328. package/dist/esm/internal/commandExecutor.js +0 -120
  329. package/dist/esm/internal/commandExecutor.js.map +0 -1
  330. package/dist/esm/internal/error.js +0 -37
  331. package/dist/esm/internal/error.js.map +0 -1
  332. package/dist/esm/internal/fileSystem.js +0 -339
  333. package/dist/esm/internal/fileSystem.js.map +0 -1
  334. package/dist/esm/internal/http/etag.js +0 -43
  335. package/dist/esm/internal/http/etag.js.map +0 -1
  336. package/dist/esm/internal/http/multipart.js +0 -85
  337. package/dist/esm/internal/http/multipart.js.map +0 -1
  338. package/dist/esm/internal/http/nodeClient.js.map +0 -1
  339. package/dist/esm/internal/path.js +0 -41
  340. package/dist/esm/internal/path.js.map +0 -1
  341. package/dist/esm/internal/runtime.js +0 -27
  342. package/dist/esm/internal/runtime.js.map +0 -1
  343. package/dist/esm/internal/sink.js +0 -19
  344. package/dist/esm/internal/sink.js.map +0 -1
  345. package/dist/esm/internal/stream.js +0 -170
  346. package/dist/esm/internal/stream.js.map +0 -1
  347. package/dist/esm/internal/terminal.js +0 -89
  348. package/dist/esm/internal/terminal.js.map +0 -1
  349. package/src/Command.ts +0 -119
  350. package/src/CommandExecutor.ts +0 -49
  351. package/src/Effectify.ts +0 -22
  352. package/src/Error.ts +0 -34
  353. package/src/FileSystem.ts +0 -84
  354. package/src/Http/Etag.ts +0 -25
  355. package/src/Http/Multipart.ts +0 -47
  356. package/src/HttpClient.ts +0 -70
  357. package/src/HttpServer.ts +0 -110
  358. package/src/KeyValueStore.ts +0 -27
  359. package/src/Path.ts +0 -33
  360. package/src/Runtime.ts +0 -32
  361. package/src/Sink.ts +0 -31
  362. package/src/Stream.ts +0 -109
  363. package/src/Terminal.ts +0 -42
  364. package/src/Transferable.ts +0 -7
  365. package/src/Worker.ts +0 -65
  366. package/src/WorkerRunner.ts +0 -45
  367. package/src/internal/commandExecutor.ts +0 -203
  368. package/src/internal/error.ts +0 -51
  369. package/src/internal/fileSystem.ts +0 -575
  370. package/src/internal/http/etag.ts +0 -44
  371. package/src/internal/http/multipart.ts +0 -107
  372. package/src/internal/path.ts +0 -58
  373. package/src/internal/runtime.ts +0 -36
  374. package/src/internal/sink.ts +0 -57
  375. package/src/internal/stream.ts +0 -325
  376. package/src/internal/terminal.ts +0 -123
@@ -1,575 +0,0 @@
1
- import { effectify } from "@effect/platform/Effectify"
2
- import * as Error from "@effect/platform/Error"
3
- import * as FileSystem from "@effect/platform/FileSystem"
4
- import * as Effect from "effect/Effect"
5
- import { pipe } from "effect/Function"
6
- import * as Layer from "effect/Layer"
7
- import * as Option from "effect/Option"
8
- import * as Crypto from "node:crypto"
9
- import * as NFS from "node:fs"
10
- import * as OS from "node:os"
11
- import * as Path from "node:path"
12
- import { handleErrnoException } from "./error.js"
13
-
14
- const handleBadArgument = (method: string) => (err: unknown) =>
15
- Error.BadArgument({
16
- module: "FileSystem",
17
- method,
18
- message: (err as Error).message ?? String(err)
19
- })
20
-
21
- // == access
22
-
23
- const access = (() => {
24
- const nodeAccess = effectify(
25
- NFS.access,
26
- handleErrnoException("FileSystem", "access"),
27
- handleBadArgument("access")
28
- )
29
- return (path: string, options?: FileSystem.AccessFileOptions) => {
30
- let mode = NFS.constants.F_OK
31
- if (options?.readable) {
32
- mode |= NFS.constants.R_OK
33
- }
34
- if (options?.writable) {
35
- mode |= NFS.constants.W_OK
36
- }
37
- return nodeAccess(path, mode)
38
- }
39
- })()
40
-
41
- // == copy
42
-
43
- const copy = (() => {
44
- const nodeCp = effectify(
45
- NFS.cp,
46
- handleErrnoException("FileSystem", "copy"),
47
- handleBadArgument("copy")
48
- )
49
- return (fromPath: string, toPath: string, options?: FileSystem.CopyOptions) =>
50
- nodeCp(fromPath, toPath, {
51
- force: options?.overwrite ?? false,
52
- preserveTimestamps: options?.preserveTimestamps ?? false,
53
- recursive: true
54
- })
55
- })()
56
-
57
- // == copyFile
58
-
59
- const copyFile = (() => {
60
- const nodeCopyFile = effectify(
61
- NFS.copyFile,
62
- handleErrnoException("FileSystem", "copyFile"),
63
- handleBadArgument("copyFile")
64
- )
65
- return (fromPath: string, toPath: string) => nodeCopyFile(fromPath, toPath)
66
- })()
67
-
68
- // == chmod
69
-
70
- const chmod = (() => {
71
- const nodeChmod = effectify(
72
- NFS.chmod,
73
- handleErrnoException("FileSystem", "chmod"),
74
- handleBadArgument("chmod")
75
- )
76
- return (path: string, mode: number) => nodeChmod(path, mode)
77
- })()
78
-
79
- // == chown
80
-
81
- const chown = (() => {
82
- const nodeChown = effectify(
83
- NFS.chown,
84
- handleErrnoException("FileSystem", "chown"),
85
- handleBadArgument("chown")
86
- )
87
- return (path: string, uid: number, gid: number) => nodeChown(path, uid, gid)
88
- })()
89
-
90
- // == link
91
-
92
- const link = (() => {
93
- const nodeLink = effectify(
94
- NFS.link,
95
- handleErrnoException("FileSystem", "link"),
96
- handleBadArgument("link")
97
- )
98
- return (existingPath: string, newPath: string) => nodeLink(existingPath, newPath)
99
- })()
100
-
101
- // == makeDirectory
102
-
103
- const makeDirectory = (() => {
104
- const nodeMkdir = effectify(
105
- NFS.mkdir,
106
- handleErrnoException("FileSystem", "makeDirectory"),
107
- handleBadArgument("makeDirectory")
108
- )
109
- return (path: string, options?: FileSystem.MakeDirectoryOptions) =>
110
- nodeMkdir(path, {
111
- recursive: options?.recursive ?? false,
112
- mode: options?.mode
113
- })
114
- })()
115
-
116
- // == makeTempDirectory
117
-
118
- const makeTempDirectoryFactory = (method: string) => {
119
- const nodeMkdtemp = effectify(
120
- NFS.mkdtemp,
121
- handleErrnoException("FileSystem", method),
122
- handleBadArgument(method)
123
- )
124
- return (options?: FileSystem.MakeTempDirectoryOptions) =>
125
- Effect.suspend(() => {
126
- const prefix = options?.prefix ?? ""
127
- const directory = typeof options?.directory === "string"
128
- ? Path.join(options.directory, ".")
129
- : OS.tmpdir()
130
-
131
- return nodeMkdtemp(prefix ? Path.join(directory, prefix) : directory + "/")
132
- })
133
- }
134
- const makeTempDirectory = makeTempDirectoryFactory("makeTempDirectory")
135
-
136
- // == remove
137
-
138
- const removeFactory = (method: string) => {
139
- const nodeRm = effectify(
140
- NFS.rm,
141
- handleErrnoException("FileSystem", method),
142
- handleBadArgument(method)
143
- )
144
- return (path: string, options?: FileSystem.RemoveOptions) =>
145
- nodeRm(
146
- path,
147
- { recursive: options?.recursive ?? false }
148
- )
149
- }
150
- const remove = removeFactory("remove")
151
-
152
- // == makeTempDirectoryScoped
153
-
154
- const makeTempDirectoryScoped = (() => {
155
- const makeDirectory = makeTempDirectoryFactory("makeTempDirectoryScoped")
156
- const removeDirectory = removeFactory("makeTempDirectoryScoped")
157
- return (
158
- options?: FileSystem.MakeTempDirectoryOptions
159
- ) =>
160
- Effect.acquireRelease(
161
- makeDirectory(options),
162
- (directory) => Effect.orDie(removeDirectory(directory, { recursive: true }))
163
- )
164
- })()
165
-
166
- // == open
167
-
168
- const openFactory = (method: string) => {
169
- const nodeOpen = effectify(
170
- NFS.open,
171
- handleErrnoException("FileSystem", method),
172
- handleBadArgument(method)
173
- )
174
- const nodeClose = effectify(
175
- NFS.close,
176
- handleErrnoException("FileSystem", method),
177
- handleBadArgument(method)
178
- )
179
-
180
- return (path: string, options?: FileSystem.OpenFileOptions) =>
181
- pipe(
182
- Effect.acquireRelease(
183
- nodeOpen(path, options?.flag ?? "r", options?.mode),
184
- (fd) => Effect.orDie(nodeClose(fd))
185
- ),
186
- Effect.map((fd) => makeFile(FileSystem.FileDescriptor(fd), options?.flag?.startsWith("a") ?? false))
187
- )
188
- }
189
- const open = openFactory("open")
190
-
191
- const makeFile = (() => {
192
- const nodeReadFactory = (method: string) =>
193
- effectify(
194
- NFS.read,
195
- handleErrnoException("FileSystem", method),
196
- handleBadArgument(method)
197
- )
198
- const nodeRead = nodeReadFactory("read")
199
- const nodeReadAlloc = nodeReadFactory("readAlloc")
200
- const nodeStat = effectify(
201
- NFS.fstat,
202
- handleErrnoException("FileSystem", "stat"),
203
- handleBadArgument("stat")
204
- )
205
- const nodeTruncate = effectify(
206
- NFS.ftruncate,
207
- handleErrnoException("FileSystem", "truncate"),
208
- handleBadArgument("truncate")
209
- )
210
-
211
- const nodeWriteFactory = (method: string) =>
212
- effectify(
213
- NFS.write,
214
- handleErrnoException("FileSystem", method),
215
- handleBadArgument(method)
216
- )
217
- const nodeWrite = nodeWriteFactory("write")
218
- const nodeWriteAll = nodeWriteFactory("writeAll")
219
-
220
- class FileImpl implements FileSystem.File {
221
- readonly [FileSystem.FileTypeId]: FileSystem.FileTypeId
222
-
223
- private readonly semaphore = Effect.unsafeMakeSemaphore(1)
224
- private position: bigint = 0n
225
-
226
- constructor(
227
- readonly fd: FileSystem.File.Descriptor,
228
- private readonly append: boolean
229
- ) {
230
- this[FileSystem.FileTypeId] = FileSystem.FileTypeId
231
- }
232
-
233
- get stat() {
234
- return Effect.map(nodeStat(this.fd), makeFileInfo)
235
- }
236
-
237
- seek(offset: FileSystem.SizeInput, from: FileSystem.SeekMode) {
238
- const offsetSize = FileSystem.Size(offset)
239
- return this.semaphore.withPermits(1)(
240
- Effect.sync(() => {
241
- if (from === "start") {
242
- this.position = offsetSize
243
- } else if (from === "current") {
244
- this.position = this.position + offsetSize
245
- }
246
-
247
- return this.position
248
- })
249
- )
250
- }
251
-
252
- read(buffer: Uint8Array) {
253
- return this.semaphore.withPermits(1)(
254
- Effect.map(
255
- Effect.suspend(() =>
256
- nodeRead(this.fd, {
257
- buffer,
258
- position: this.position
259
- })
260
- ),
261
- (bytesRead) => {
262
- const sizeRead = FileSystem.Size(bytesRead)
263
- this.position = this.position + sizeRead
264
- return sizeRead
265
- }
266
- )
267
- )
268
- }
269
-
270
- readAlloc(size: FileSystem.SizeInput) {
271
- const sizeNumber = Number(size)
272
- return this.semaphore.withPermits(1)(Effect.flatMap(
273
- Effect.sync(() => Buffer.allocUnsafeSlow(sizeNumber)),
274
- (buffer) =>
275
- Effect.map(
276
- nodeReadAlloc(this.fd, {
277
- buffer,
278
- position: this.position
279
- }),
280
- (bytesRead): Option.Option<Buffer> => {
281
- if (bytesRead === 0) {
282
- return Option.none()
283
- }
284
-
285
- this.position = this.position + BigInt(bytesRead)
286
- if (bytesRead === sizeNumber) {
287
- return Option.some(buffer)
288
- }
289
-
290
- const dst = Buffer.allocUnsafeSlow(bytesRead)
291
- buffer.copy(dst, 0, 0, bytesRead)
292
- return Option.some(dst)
293
- }
294
- )
295
- ))
296
- }
297
-
298
- truncate(length?: FileSystem.SizeInput) {
299
- return this.semaphore.withPermits(1)(
300
- Effect.map(nodeTruncate(this.fd, length ? Number(length) : undefined), () => {
301
- if (!this.append) {
302
- const len = BigInt(length ?? 0)
303
- if (this.position > len) {
304
- this.position = len
305
- }
306
- }
307
- })
308
- )
309
- }
310
-
311
- write(buffer: Uint8Array) {
312
- return this.semaphore.withPermits(1)(
313
- Effect.map(
314
- Effect.suspend(() =>
315
- nodeWrite(this.fd, buffer, undefined, undefined, this.append ? undefined : Number(this.position))
316
- ),
317
- (bytesWritten) => {
318
- const sizeWritten = FileSystem.Size(bytesWritten)
319
- if (!this.append) {
320
- this.position = this.position + sizeWritten
321
- }
322
-
323
- return sizeWritten
324
- }
325
- )
326
- )
327
- }
328
-
329
- private writeAllChunk(buffer: Uint8Array): Effect.Effect<never, Error.PlatformError, void> {
330
- return Effect.flatMap(
331
- Effect.suspend(() =>
332
- nodeWriteAll(this.fd, buffer, undefined, undefined, this.append ? undefined : Number(this.position))
333
- ),
334
- (bytesWritten) => {
335
- if (bytesWritten === 0) {
336
- return Effect.fail(Error.SystemError({
337
- module: "FileSystem",
338
- method: "writeAll",
339
- reason: "WriteZero",
340
- pathOrDescriptor: this.fd,
341
- message: "write returned 0 bytes written"
342
- }))
343
- }
344
-
345
- if (!this.append) {
346
- this.position = this.position + BigInt(bytesWritten)
347
- }
348
-
349
- return bytesWritten < buffer.length ? this.writeAllChunk(buffer.subarray(bytesWritten)) : Effect.unit
350
- }
351
- )
352
- }
353
-
354
- writeAll(buffer: Uint8Array) {
355
- return this.semaphore.withPermits(1)(this.writeAllChunk(buffer))
356
- }
357
- }
358
-
359
- return (fd: FileSystem.File.Descriptor, append: boolean): FileSystem.File => new FileImpl(fd, append)
360
- })()
361
-
362
- // == makeTempFile
363
-
364
- const makeTempFileFactory = (method: string) => {
365
- const makeDirectory = makeTempDirectoryFactory(method)
366
- const open = openFactory(method)
367
- const randomHexString = (bytes: number) => Effect.sync(() => Crypto.randomBytes(bytes).toString("hex"))
368
- return (options?: FileSystem.MakeTempFileOptions) =>
369
- pipe(
370
- Effect.zip(makeDirectory(options), randomHexString(6)),
371
- Effect.map(([directory, random]) => Path.join(directory, random)),
372
- Effect.tap((path) => Effect.scoped(open(path, { flag: "w+" })))
373
- )
374
- }
375
- const makeTempFile = makeTempFileFactory("makeTempFile")
376
-
377
- // == makeTempFileScoped
378
-
379
- const makeTempFileScoped = (() => {
380
- const makeFile = makeTempFileFactory("makeTempFileScoped")
381
- const removeFile = removeFactory("makeTempFileScoped")
382
- return (options?: FileSystem.MakeTempFileOptions) =>
383
- Effect.acquireRelease(
384
- makeFile(options),
385
- (file) => Effect.orDie(removeFile(file))
386
- )
387
- })()
388
-
389
- // == readDirectory
390
-
391
- const readDirectory = (() => {
392
- const nodeReadDirectory = effectify(
393
- NFS.readdir,
394
- handleErrnoException("FileSystem", "readDirectory"),
395
- handleBadArgument("readDirectory")
396
- )
397
-
398
- return (path: string, options?: FileSystem.ReadDirectoryOptions) =>
399
- nodeReadDirectory(path, options) as Effect.Effect<never, Error.PlatformError, ReadonlyArray<string>>
400
- })()
401
-
402
- // == readFile
403
-
404
- const readFile = (path: string) =>
405
- Effect.async<never, Error.PlatformError, Uint8Array>((resume, signal) => {
406
- try {
407
- NFS.readFile(path, { signal }, (err, data) => {
408
- if (err) {
409
- resume(Effect.fail(handleErrnoException("FileSystem", "readFile")(err, [path])))
410
- } else {
411
- resume(Effect.succeed(data))
412
- }
413
- })
414
- } catch (err) {
415
- resume(Effect.fail(handleBadArgument("readFile")(err)))
416
- }
417
- })
418
-
419
- // == readLink
420
-
421
- const readLink = (() => {
422
- const nodeReadLink = effectify(
423
- NFS.readlink,
424
- handleErrnoException("FileSystem", "readLink"),
425
- handleBadArgument("readLink")
426
- )
427
- return (path: string) => nodeReadLink(path)
428
- })()
429
-
430
- // == realPath
431
-
432
- const realPath = (() => {
433
- const nodeRealPath = effectify(
434
- NFS.realpath,
435
- handleErrnoException("FileSystem", "realPath"),
436
- handleBadArgument("realPath")
437
- )
438
- return (path: string) => nodeRealPath(path)
439
- })()
440
-
441
- // == rename
442
-
443
- const rename = (() => {
444
- const nodeRename = effectify(
445
- NFS.rename,
446
- handleErrnoException("FileSystem", "rename"),
447
- handleBadArgument("rename")
448
- )
449
- return (oldPath: string, newPath: string) => nodeRename(oldPath, newPath)
450
- })()
451
-
452
- // == stat
453
-
454
- const makeFileInfo = (stat: NFS.Stats): FileSystem.File.Info => ({
455
- type: stat.isFile() ?
456
- "File" :
457
- stat.isDirectory() ?
458
- "Directory" :
459
- stat.isSymbolicLink() ?
460
- "SymbolicLink" :
461
- stat.isBlockDevice() ?
462
- "BlockDevice" :
463
- stat.isCharacterDevice() ?
464
- "CharacterDevice" :
465
- stat.isFIFO() ?
466
- "FIFO" :
467
- stat.isSocket() ?
468
- "Socket" :
469
- "Unknown",
470
- mtime: Option.fromNullable(stat.mtime),
471
- atime: Option.fromNullable(stat.atime),
472
- birthtime: Option.fromNullable(stat.birthtime),
473
- dev: stat.dev,
474
- rdev: Option.fromNullable(stat.rdev),
475
- ino: Option.fromNullable(stat.ino),
476
- mode: stat.mode,
477
- nlink: Option.fromNullable(stat.nlink),
478
- uid: Option.fromNullable(stat.uid),
479
- gid: Option.fromNullable(stat.gid),
480
- size: FileSystem.Size(stat.size),
481
- blksize: Option.fromNullable(FileSystem.Size(stat.blksize)),
482
- blocks: Option.fromNullable(stat.blocks)
483
- })
484
- const stat = (() => {
485
- const nodeStat = effectify(
486
- NFS.stat,
487
- handleErrnoException("FileSystem", "stat"),
488
- handleBadArgument("stat")
489
- )
490
- return (path: string) => Effect.map(nodeStat(path), makeFileInfo)
491
- })()
492
-
493
- // == symlink
494
-
495
- const symlink = (() => {
496
- const nodeSymlink = effectify(
497
- NFS.symlink,
498
- handleErrnoException("FileSystem", "symlink"),
499
- handleBadArgument("symlink")
500
- )
501
- return (target: string, path: string) => nodeSymlink(target, path)
502
- })()
503
-
504
- // == truncate
505
-
506
- const truncate = (() => {
507
- const nodeTruncate = effectify(
508
- NFS.truncate,
509
- handleErrnoException("FileSystem", "truncate"),
510
- handleBadArgument("truncate")
511
- )
512
- return (path: string, length?: FileSystem.SizeInput) =>
513
- nodeTruncate(path, length !== undefined ? Number(length) : undefined)
514
- })()
515
-
516
- // == utimes
517
-
518
- const utimes = (() => {
519
- const nodeUtimes = effectify(
520
- NFS.utimes,
521
- handleErrnoException("FileSystem", "utime"),
522
- handleBadArgument("utime")
523
- )
524
- return (path: string, atime: number | Date, mtime: number | Date) => nodeUtimes(path, atime, mtime)
525
- })()
526
-
527
- // == writeFile
528
-
529
- const writeFile = (path: string, data: Uint8Array, options?: FileSystem.WriteFileOptions) =>
530
- Effect.async<never, Error.PlatformError, void>((resume, signal) => {
531
- try {
532
- NFS.writeFile(path, data, {
533
- signal,
534
- flag: options?.flag,
535
- mode: options?.mode
536
- }, (err) => {
537
- if (err) {
538
- resume(Effect.fail(handleErrnoException("FileSystem", "writeFile")(err, [path])))
539
- } else {
540
- resume(Effect.unit)
541
- }
542
- })
543
- } catch (err) {
544
- resume(Effect.fail(handleBadArgument("writeFile")(err)))
545
- }
546
- })
547
-
548
- const fileSystemImpl = FileSystem.make({
549
- access,
550
- chmod,
551
- chown,
552
- copy,
553
- copyFile,
554
- link,
555
- makeDirectory,
556
- makeTempDirectory,
557
- makeTempDirectoryScoped,
558
- makeTempFile,
559
- makeTempFileScoped,
560
- open,
561
- readDirectory,
562
- readFile,
563
- readLink,
564
- realPath,
565
- remove,
566
- rename,
567
- stat,
568
- symlink,
569
- truncate,
570
- utimes,
571
- writeFile
572
- })
573
-
574
- /** @internal */
575
- export const layer = Layer.succeed(FileSystem.FileSystem, fileSystemImpl)
@@ -1,44 +0,0 @@
1
- import type * as FileSystem from "@effect/platform/FileSystem"
2
- import type * as Body from "@effect/platform/Http/Body"
3
- import * as Etag from "@effect/platform/Http/Etag"
4
- import * as Effect from "effect/Effect"
5
- import * as Layer from "effect/Layer"
6
-
7
- const fromFileInfo = (info: FileSystem.File.Info) => {
8
- const mtime = info.mtime._tag === "Some"
9
- ? info.mtime.value.getTime().toString(16)
10
- : "0"
11
- return `${info.size.toString(16)}-${mtime}`
12
- }
13
-
14
- const fromFileWeb = (file: Body.Body.FileLike) => {
15
- return `${file.size.toString(16)}-${file.lastModified.toString(16)}`
16
- }
17
-
18
- /** @internal */
19
- export const layer = Layer.succeed(
20
- Etag.Generator,
21
- Etag.Generator.of({
22
- [Etag.GeneratorTypeId]: Etag.GeneratorTypeId,
23
- fromFileInfo(info) {
24
- return Effect.sync(() => ({ _tag: "Strong", value: fromFileInfo(info) }))
25
- },
26
- fromFileWeb(file) {
27
- return Effect.sync(() => ({ _tag: "Strong", value: fromFileWeb(file) }))
28
- }
29
- })
30
- )
31
-
32
- /** @internal */
33
- export const layerWeak = Layer.succeed(
34
- Etag.Generator,
35
- Etag.Generator.of({
36
- [Etag.GeneratorTypeId]: Etag.GeneratorTypeId,
37
- fromFileInfo(info) {
38
- return Effect.sync(() => ({ _tag: "Weak", value: fromFileInfo(info) }))
39
- },
40
- fromFileWeb(file) {
41
- return Effect.sync(() => ({ _tag: "Weak", value: fromFileWeb(file) }))
42
- }
43
- })
44
- )