@effect/platform 0.66.2 → 0.67.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 (178) hide show
  1. package/dist/cjs/Command.js.map +1 -1
  2. package/dist/cjs/Cookies.js.map +1 -1
  3. package/dist/cjs/Effectify.js.map +1 -1
  4. package/dist/cjs/Headers.js.map +1 -1
  5. package/dist/cjs/HttpApi.js.map +1 -1
  6. package/dist/cjs/HttpApiBuilder.js.map +1 -1
  7. package/dist/cjs/HttpApiEndpoint.js.map +1 -1
  8. package/dist/cjs/HttpApiGroup.js.map +1 -1
  9. package/dist/cjs/HttpApiSchema.js.map +1 -1
  10. package/dist/cjs/HttpApiSecurity.js.map +1 -1
  11. package/dist/cjs/HttpApp.js.map +1 -1
  12. package/dist/cjs/HttpClient.js +8 -1
  13. package/dist/cjs/HttpClient.js.map +1 -1
  14. package/dist/cjs/HttpClientError.js +8 -1
  15. package/dist/cjs/HttpClientError.js.map +1 -1
  16. package/dist/cjs/HttpClientRequest.js.map +1 -1
  17. package/dist/cjs/HttpClientResponse.js +11 -1
  18. package/dist/cjs/HttpClientResponse.js.map +1 -1
  19. package/dist/cjs/HttpIncomingMessage.js.map +1 -1
  20. package/dist/cjs/HttpMiddleware.js.map +1 -1
  21. package/dist/cjs/HttpMultiplex.js.map +1 -1
  22. package/dist/cjs/HttpRouter.js.map +1 -1
  23. package/dist/cjs/HttpServer.js.map +1 -1
  24. package/dist/cjs/HttpServerResponse.js.map +1 -1
  25. package/dist/cjs/KeyValueStore.js.map +1 -1
  26. package/dist/cjs/Multipart.js.map +1 -1
  27. package/dist/cjs/OpenApi.js.map +1 -1
  28. package/dist/cjs/PlatformLogger.js.map +1 -1
  29. package/dist/cjs/Socket.js +4 -1
  30. package/dist/cjs/Socket.js.map +1 -1
  31. package/dist/cjs/Transferable.js.map +1 -1
  32. package/dist/cjs/UrlParams.js.map +1 -1
  33. package/dist/cjs/internal/httpBody.js +3 -0
  34. package/dist/cjs/internal/httpBody.js.map +1 -1
  35. package/dist/cjs/internal/httpClient.js +12 -14
  36. package/dist/cjs/internal/httpClient.js.map +1 -1
  37. package/dist/cjs/internal/httpClientResponse.js +16 -1
  38. package/dist/cjs/internal/httpClientResponse.js.map +1 -1
  39. package/dist/cjs/internal/httpMultiplex.js +3 -0
  40. package/dist/cjs/internal/httpMultiplex.js.map +1 -1
  41. package/dist/cjs/internal/httpRouter.js +3 -0
  42. package/dist/cjs/internal/httpRouter.js.map +1 -1
  43. package/dist/cjs/internal/httpServerResponse.js +3 -0
  44. package/dist/cjs/internal/httpServerResponse.js.map +1 -1
  45. package/dist/dts/Command.d.ts +134 -0
  46. package/dist/dts/Command.d.ts.map +1 -1
  47. package/dist/dts/Cookies.d.ts +120 -0
  48. package/dist/dts/Cookies.d.ts.map +1 -1
  49. package/dist/dts/Effectify.d.ts +9 -0
  50. package/dist/dts/Effectify.d.ts.map +1 -1
  51. package/dist/dts/Headers.d.ts +56 -0
  52. package/dist/dts/Headers.d.ts.map +1 -1
  53. package/dist/dts/HttpApi.d.ts +58 -0
  54. package/dist/dts/HttpApi.d.ts.map +1 -1
  55. package/dist/dts/HttpApiBuilder.d.ts +84 -0
  56. package/dist/dts/HttpApiBuilder.d.ts.map +1 -1
  57. package/dist/dts/HttpApiEndpoint.d.ts +118 -0
  58. package/dist/dts/HttpApiEndpoint.d.ts.map +1 -1
  59. package/dist/dts/HttpApiGroup.d.ts +100 -0
  60. package/dist/dts/HttpApiGroup.d.ts.map +1 -1
  61. package/dist/dts/HttpApiSchema.d.ts +16 -0
  62. package/dist/dts/HttpApiSchema.d.ts.map +1 -1
  63. package/dist/dts/HttpApiSecurity.d.ts +16 -0
  64. package/dist/dts/HttpApiSecurity.d.ts.map +1 -1
  65. package/dist/dts/HttpApp.d.ts.map +1 -1
  66. package/dist/dts/HttpClient.d.ts +308 -0
  67. package/dist/dts/HttpClient.d.ts.map +1 -1
  68. package/dist/dts/HttpClientError.d.ts +5 -0
  69. package/dist/dts/HttpClientError.d.ts.map +1 -1
  70. package/dist/dts/HttpClientRequest.d.ts +208 -0
  71. package/dist/dts/HttpClientRequest.d.ts.map +1 -1
  72. package/dist/dts/HttpClientResponse.d.ts +30 -0
  73. package/dist/dts/HttpClientResponse.d.ts.map +1 -1
  74. package/dist/dts/HttpIncomingMessage.d.ts.map +1 -1
  75. package/dist/dts/HttpMiddleware.d.ts +24 -0
  76. package/dist/dts/HttpMiddleware.d.ts.map +1 -1
  77. package/dist/dts/HttpMultiplex.d.ts +72 -0
  78. package/dist/dts/HttpMultiplex.d.ts.map +1 -1
  79. package/dist/dts/HttpRouter.d.ts +184 -0
  80. package/dist/dts/HttpRouter.d.ts.map +1 -1
  81. package/dist/dts/HttpServer.d.ts +32 -0
  82. package/dist/dts/HttpServer.d.ts.map +1 -1
  83. package/dist/dts/HttpServerResponse.d.ts +96 -0
  84. package/dist/dts/HttpServerResponse.d.ts.map +1 -1
  85. package/dist/dts/KeyValueStore.d.ts +8 -0
  86. package/dist/dts/KeyValueStore.d.ts.map +1 -1
  87. package/dist/dts/Multipart.d.ts +32 -0
  88. package/dist/dts/Multipart.d.ts.map +1 -1
  89. package/dist/dts/OpenApi.d.ts +8 -0
  90. package/dist/dts/OpenApi.d.ts.map +1 -1
  91. package/dist/dts/PlatformLogger.d.ts +46 -0
  92. package/dist/dts/PlatformLogger.d.ts.map +1 -1
  93. package/dist/dts/Socket.d.ts +8 -0
  94. package/dist/dts/Socket.d.ts.map +1 -1
  95. package/dist/dts/Transferable.d.ts +8 -0
  96. package/dist/dts/Transferable.d.ts.map +1 -1
  97. package/dist/dts/UrlParams.d.ts +64 -0
  98. package/dist/dts/UrlParams.d.ts.map +1 -1
  99. package/dist/dts/internal/httpRouter.d.ts.map +1 -1
  100. package/dist/esm/Command.js.map +1 -1
  101. package/dist/esm/Cookies.js.map +1 -1
  102. package/dist/esm/Effectify.js.map +1 -1
  103. package/dist/esm/Headers.js.map +1 -1
  104. package/dist/esm/HttpApi.js.map +1 -1
  105. package/dist/esm/HttpApiBuilder.js.map +1 -1
  106. package/dist/esm/HttpApiEndpoint.js.map +1 -1
  107. package/dist/esm/HttpApiGroup.js.map +1 -1
  108. package/dist/esm/HttpApiSchema.js.map +1 -1
  109. package/dist/esm/HttpApiSecurity.js.map +1 -1
  110. package/dist/esm/HttpApp.js.map +1 -1
  111. package/dist/esm/HttpClient.js +7 -0
  112. package/dist/esm/HttpClient.js.map +1 -1
  113. package/dist/esm/HttpClientError.js +6 -0
  114. package/dist/esm/HttpClientError.js.map +1 -1
  115. package/dist/esm/HttpClientRequest.js.map +1 -1
  116. package/dist/esm/HttpClientResponse.js +10 -0
  117. package/dist/esm/HttpClientResponse.js.map +1 -1
  118. package/dist/esm/HttpIncomingMessage.js.map +1 -1
  119. package/dist/esm/HttpMiddleware.js.map +1 -1
  120. package/dist/esm/HttpMultiplex.js.map +1 -1
  121. package/dist/esm/HttpRouter.js.map +1 -1
  122. package/dist/esm/HttpServer.js.map +1 -1
  123. package/dist/esm/HttpServerResponse.js.map +1 -1
  124. package/dist/esm/KeyValueStore.js.map +1 -1
  125. package/dist/esm/Multipart.js.map +1 -1
  126. package/dist/esm/OpenApi.js.map +1 -1
  127. package/dist/esm/PlatformLogger.js.map +1 -1
  128. package/dist/esm/Socket.js +4 -1
  129. package/dist/esm/Socket.js.map +1 -1
  130. package/dist/esm/Transferable.js.map +1 -1
  131. package/dist/esm/UrlParams.js.map +1 -1
  132. package/dist/esm/internal/httpBody.js +3 -0
  133. package/dist/esm/internal/httpBody.js.map +1 -1
  134. package/dist/esm/internal/httpClient.js +11 -13
  135. package/dist/esm/internal/httpClient.js.map +1 -1
  136. package/dist/esm/internal/httpClientResponse.js +14 -0
  137. package/dist/esm/internal/httpClientResponse.js.map +1 -1
  138. package/dist/esm/internal/httpMultiplex.js +3 -0
  139. package/dist/esm/internal/httpMultiplex.js.map +1 -1
  140. package/dist/esm/internal/httpRouter.js +3 -0
  141. package/dist/esm/internal/httpRouter.js.map +1 -1
  142. package/dist/esm/internal/httpServerResponse.js +3 -0
  143. package/dist/esm/internal/httpServerResponse.js.map +1 -1
  144. package/package.json +3 -3
  145. package/src/Command.ts +134 -0
  146. package/src/Cookies.ts +128 -38
  147. package/src/Effectify.ts +9 -0
  148. package/src/Headers.ts +106 -7
  149. package/src/HttpApi.ts +58 -0
  150. package/src/HttpApiBuilder.ts +85 -3
  151. package/src/HttpApiEndpoint.ts +121 -9
  152. package/src/HttpApiGroup.ts +102 -7
  153. package/src/HttpApiSchema.ts +22 -4
  154. package/src/HttpApiSecurity.ts +16 -0
  155. package/src/HttpApp.ts +8 -0
  156. package/src/HttpClient.ts +315 -11
  157. package/src/HttpClientError.ts +7 -0
  158. package/src/HttpClientRequest.ts +213 -1
  159. package/src/HttpClientResponse.ts +33 -0
  160. package/src/HttpIncomingMessage.ts +8 -0
  161. package/src/HttpMiddleware.ts +24 -0
  162. package/src/HttpMultiplex.ts +72 -0
  163. package/src/HttpRouter.ts +189 -18
  164. package/src/HttpServer.ts +34 -6
  165. package/src/HttpServerResponse.ts +98 -10
  166. package/src/KeyValueStore.ts +8 -0
  167. package/src/Multipart.ts +32 -0
  168. package/src/OpenApi.ts +31 -18
  169. package/src/PlatformLogger.ts +46 -0
  170. package/src/Socket.ts +19 -13
  171. package/src/Transferable.ts +9 -3
  172. package/src/UrlParams.ts +64 -0
  173. package/src/internal/httpBody.ts +3 -0
  174. package/src/internal/httpClient.ts +41 -26
  175. package/src/internal/httpClientResponse.ts +40 -1
  176. package/src/internal/httpMultiplex.ts +3 -0
  177. package/src/internal/httpRouter.ts +3 -0
  178. package/src/internal/httpServerResponse.ts +3 -0
@@ -102,10 +102,18 @@ export const text: (body: string, options?: Options.WithContentType | undefined)
102
102
  * @category constructors
103
103
  */
104
104
  export const html: {
105
+ /**
106
+ * @since 1.0.0
107
+ * @category constructors
108
+ */
105
109
  <A extends ReadonlyArray<Template.Interpolated>>(
106
110
  strings: TemplateStringsArray,
107
111
  ...args: A
108
112
  ): Effect.Effect<HttpServerResponse, Template.Interpolated.Error<A[number]>, Template.Interpolated.Context<A[number]>>
113
+ /**
114
+ * @since 1.0.0
115
+ * @category constructors
116
+ */
109
117
  (html: string): HttpServerResponse
110
118
  } = internal.html
111
119
 
@@ -196,7 +204,15 @@ export const fileWeb: (
196
204
  * @category combinators
197
205
  */
198
206
  export const setHeader: {
207
+ /**
208
+ * @since 1.0.0
209
+ * @category combinators
210
+ */
199
211
  (key: string, value: string): (self: HttpServerResponse) => HttpServerResponse
212
+ /**
213
+ * @since 1.0.0
214
+ * @category combinators
215
+ */
200
216
  (self: HttpServerResponse, key: string, value: string): HttpServerResponse
201
217
  } = internal.setHeader
202
218
 
@@ -205,7 +221,15 @@ export const setHeader: {
205
221
  * @category combinators
206
222
  */
207
223
  export const setHeaders: {
224
+ /**
225
+ * @since 1.0.0
226
+ * @category combinators
227
+ */
208
228
  (input: Headers.Input): (self: HttpServerResponse) => HttpServerResponse
229
+ /**
230
+ * @since 1.0.0
231
+ * @category combinators
232
+ */
209
233
  (self: HttpServerResponse, input: Headers.Input): HttpServerResponse
210
234
  } = internal.setHeaders
211
235
 
@@ -214,7 +238,15 @@ export const setHeaders: {
214
238
  * @category combinators
215
239
  */
216
240
  export const removeCookie: {
241
+ /**
242
+ * @since 1.0.0
243
+ * @category combinators
244
+ */
217
245
  (name: string): (self: HttpServerResponse) => HttpServerResponse
246
+ /**
247
+ * @since 1.0.0
248
+ * @category combinators
249
+ */
218
250
  (self: HttpServerResponse, name: string): HttpServerResponse
219
251
  } = internal.removeCookie
220
252
 
@@ -223,7 +255,15 @@ export const removeCookie: {
223
255
  * @category combinators
224
256
  */
225
257
  export const replaceCookies: {
258
+ /**
259
+ * @since 1.0.0
260
+ * @category combinators
261
+ */
226
262
  (cookies: Cookies): (self: HttpServerResponse) => HttpServerResponse
263
+ /**
264
+ * @since 1.0.0
265
+ * @category combinators
266
+ */
227
267
  (self: HttpServerResponse, cookies: Cookies): HttpServerResponse
228
268
  } = internal.replaceCookies
229
269
 
@@ -232,16 +272,20 @@ export const replaceCookies: {
232
272
  * @category combinators
233
273
  */
234
274
  export const setCookie: {
235
- (
236
- name: string,
237
- value: string,
238
- options?: Cookie["options"]
239
- ): (
275
+ /**
276
+ * @since 1.0.0
277
+ * @category combinators
278
+ */
279
+ (name: string, value: string, options?: Cookie["options"]): (
240
280
  self: HttpServerResponse
241
281
  ) => Effect.Effect<
242
282
  HttpServerResponse,
243
283
  CookiesError
244
284
  >
285
+ /**
286
+ * @since 1.0.0
287
+ * @category combinators
288
+ */
245
289
  (
246
290
  self: HttpServerResponse,
247
291
  name: string,
@@ -258,11 +302,15 @@ export const setCookie: {
258
302
  * @category combinators
259
303
  */
260
304
  export const unsafeSetCookie: {
261
- (
262
- name: string,
263
- value: string,
264
- options?: Cookie["options"]
265
- ): (self: HttpServerResponse) => HttpServerResponse
305
+ /**
306
+ * @since 1.0.0
307
+ * @category combinators
308
+ */
309
+ (name: string, value: string, options?: Cookie["options"]): (self: HttpServerResponse) => HttpServerResponse
310
+ /**
311
+ * @since 1.0.0
312
+ * @category combinators
313
+ */
266
314
  (
267
315
  self: HttpServerResponse,
268
316
  name: string,
@@ -276,7 +324,15 @@ export const unsafeSetCookie: {
276
324
  * @category combinators
277
325
  */
278
326
  export const updateCookies: {
327
+ /**
328
+ * @since 1.0.0
329
+ * @category combinators
330
+ */
279
331
  (f: (cookies: Cookies) => Cookies): (self: HttpServerResponse) => HttpServerResponse
332
+ /**
333
+ * @since 1.0.0
334
+ * @category combinators
335
+ */
280
336
  (self: HttpServerResponse, f: (cookies: Cookies) => Cookies): HttpServerResponse
281
337
  } = internal.updateCookies
282
338
 
@@ -285,6 +341,10 @@ export const updateCookies: {
285
341
  * @category combinators
286
342
  */
287
343
  export const setCookies: {
344
+ /**
345
+ * @since 1.0.0
346
+ * @category combinators
347
+ */
288
348
  (
289
349
  cookies: Iterable<
290
350
  readonly [
@@ -294,6 +354,10 @@ export const setCookies: {
294
354
  ]
295
355
  >
296
356
  ): (self: HttpServerResponse) => Effect.Effect<HttpServerResponse, CookiesError, never>
357
+ /**
358
+ * @since 1.0.0
359
+ * @category combinators
360
+ */
297
361
  (
298
362
  self: HttpServerResponse,
299
363
  cookies: Iterable<
@@ -311,6 +375,10 @@ export const setCookies: {
311
375
  * @category combinators
312
376
  */
313
377
  export const unsafeSetCookies: {
378
+ /**
379
+ * @since 1.0.0
380
+ * @category combinators
381
+ */
314
382
  (
315
383
  cookies: Iterable<
316
384
  readonly [
@@ -320,6 +388,10 @@ export const unsafeSetCookies: {
320
388
  ]
321
389
  >
322
390
  ): (self: HttpServerResponse) => HttpServerResponse
391
+ /**
392
+ * @since 1.0.0
393
+ * @category combinators
394
+ */
323
395
  (
324
396
  self: HttpServerResponse,
325
397
  cookies: Iterable<
@@ -337,7 +409,15 @@ export const unsafeSetCookies: {
337
409
  * @category combinators
338
410
  */
339
411
  export const setBody: {
412
+ /**
413
+ * @since 1.0.0
414
+ * @category combinators
415
+ */
340
416
  (body: Body.HttpBody): (self: HttpServerResponse) => HttpServerResponse
417
+ /**
418
+ * @since 1.0.0
419
+ * @category combinators
420
+ */
341
421
  (self: HttpServerResponse, body: Body.HttpBody): HttpServerResponse
342
422
  } = internal.setBody
343
423
 
@@ -346,7 +426,15 @@ export const setBody: {
346
426
  * @category combinators
347
427
  */
348
428
  export const setStatus: {
429
+ /**
430
+ * @since 1.0.0
431
+ * @category combinators
432
+ */
349
433
  (status: number, statusText?: string | undefined): (self: HttpServerResponse) => HttpServerResponse
434
+ /**
435
+ * @since 1.0.0
436
+ * @category combinators
437
+ */
350
438
  (self: HttpServerResponse, status: number, statusText?: string | undefined): HttpServerResponse
351
439
  } = internal.setStatus
352
440
 
@@ -132,7 +132,15 @@ export const makeStringOnly: (
132
132
  * @category combinators
133
133
  */
134
134
  export const prefix: {
135
+ /**
136
+ * @since 1.0.0
137
+ * @category combinators
138
+ */
135
139
  (prefix: string): <S extends KeyValueStore.AnyStore>(self: S) => S
140
+ /**
141
+ * @since 1.0.0
142
+ * @category combinators
143
+ */
136
144
  <S extends KeyValueStore.AnyStore>(self: S, prefix: string): S
137
145
  } = internal.prefix
138
146
 
package/src/Multipart.ts CHANGED
@@ -163,7 +163,15 @@ export const maxParts: FiberRef.FiberRef<Option.Option<number>> = internal.maxPa
163
163
  * @category fiber refs
164
164
  */
165
165
  export const withMaxParts: {
166
+ /**
167
+ * @since 1.0.0
168
+ * @category fiber refs
169
+ */
166
170
  (count: Option.Option<number>): <A, E, R>(effect: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
171
+ /**
172
+ * @since 1.0.0
173
+ * @category fiber refs
174
+ */
167
175
  <A, E, R>(effect: Effect.Effect<A, E, R>, count: Option.Option<number>): Effect.Effect<A, E, R>
168
176
  } = internal.withMaxParts
169
177
 
@@ -178,7 +186,15 @@ export const maxFieldSize: FiberRef.FiberRef<FileSystem.Size> = internal.maxFiel
178
186
  * @category fiber refs
179
187
  */
180
188
  export const withMaxFieldSize: {
189
+ /**
190
+ * @since 1.0.0
191
+ * @category fiber refs
192
+ */
181
193
  (size: FileSystem.SizeInput): <A, E, R>(effect: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
194
+ /**
195
+ * @since 1.0.0
196
+ * @category fiber refs
197
+ */
182
198
  <A, E, R>(effect: Effect.Effect<A, E, R>, size: FileSystem.SizeInput): Effect.Effect<A, E, R>
183
199
  } = internal.withMaxFieldSize
184
200
 
@@ -193,7 +209,15 @@ export const maxFileSize: FiberRef.FiberRef<Option.Option<FileSystem.Size>> = in
193
209
  * @category fiber refs
194
210
  */
195
211
  export const withMaxFileSize: {
212
+ /**
213
+ * @since 1.0.0
214
+ * @category fiber refs
215
+ */
196
216
  (size: Option.Option<FileSystem.SizeInput>): <A, E, R>(effect: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
217
+ /**
218
+ * @since 1.0.0
219
+ * @category fiber refs
220
+ */
197
221
  <A, E, R>(effect: Effect.Effect<A, E, R>, size: Option.Option<FileSystem.SizeInput>): Effect.Effect<A, E, R>
198
222
  } = internal.withMaxFileSize
199
223
 
@@ -208,7 +232,15 @@ export const fieldMimeTypes: FiberRef.FiberRef<Chunk.Chunk<string>> = internal.f
208
232
  * @category fiber refs
209
233
  */
210
234
  export const withFieldMimeTypes: {
235
+ /**
236
+ * @since 1.0.0
237
+ * @category fiber refs
238
+ */
211
239
  (mimeTypes: ReadonlyArray<string>): <A, E, R>(effect: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
240
+ /**
241
+ * @since 1.0.0
242
+ * @category fiber refs
243
+ */
212
244
  <A, E, R>(effect: Effect.Effect<A, E, R>, mimeTypes: ReadonlyArray<string>): Effect.Effect<A, E, R>
213
245
  } = internal.withFieldMimeTypes
214
246
 
package/src/OpenApi.ts CHANGED
@@ -109,24 +109,37 @@ export interface Annotatable {
109
109
  * @category annotations
110
110
  */
111
111
  export const annotate: {
112
- (annotations: {
113
- readonly identifier?: string | undefined
114
- readonly title?: string | undefined
115
- readonly description?: string | undefined
116
- readonly version?: string | undefined
117
- readonly license?: OpenAPISpecLicense | undefined
118
- readonly security?: HttpApiSecurity | undefined
119
- readonly externalDocs?: OpenAPISpecExternalDocs | undefined
120
- }): <A extends Annotatable>(self: A) => A
121
- <A extends Annotatable>(self: A, annotations: {
122
- readonly identifier?: string | undefined
123
- readonly title?: string | undefined
124
- readonly description?: string | undefined
125
- readonly version?: string | undefined
126
- readonly license?: OpenAPISpecLicense | undefined
127
- readonly security?: HttpApiSecurity | undefined
128
- readonly externalDocs?: OpenAPISpecExternalDocs | undefined
129
- }): A
112
+ /**
113
+ * @since 1.0.0
114
+ * @category annotations
115
+ */
116
+ (
117
+ annotations: {
118
+ readonly identifier?: string | undefined
119
+ readonly title?: string | undefined
120
+ readonly description?: string | undefined
121
+ readonly version?: string | undefined
122
+ readonly license?: OpenAPISpecLicense | undefined
123
+ readonly security?: HttpApiSecurity | undefined
124
+ readonly externalDocs?: OpenAPISpecExternalDocs | undefined
125
+ }
126
+ ): <A extends Annotatable>(self: A) => A
127
+ /**
128
+ * @since 1.0.0
129
+ * @category annotations
130
+ */
131
+ <A extends Annotatable>(
132
+ self: A,
133
+ annotations: {
134
+ readonly identifier?: string | undefined
135
+ readonly title?: string | undefined
136
+ readonly description?: string | undefined
137
+ readonly version?: string | undefined
138
+ readonly license?: OpenAPISpecLicense | undefined
139
+ readonly security?: HttpApiSecurity | undefined
140
+ readonly externalDocs?: OpenAPISpecExternalDocs | undefined
141
+ }
142
+ ): A
130
143
  } = dual(2, <A extends Annotatable>(self: A, annotations_: {
131
144
  readonly identifier?: string | undefined
132
145
  readonly title?: string | undefined
@@ -33,6 +33,29 @@ import * as internal from "./internal/platformLogger.js"
33
33
  * )
34
34
  */
35
35
  export const toFile: {
36
+ /**
37
+ * Create a Logger from another string Logger that writes to the specified file.
38
+ *
39
+ * @since 1.0.0
40
+ * @example
41
+ * import { PlatformLogger } from "@effect/platform"
42
+ * import { NodeFileSystem, NodeRuntime } from "@effect/platform-node"
43
+ * import { Effect, Layer, Logger } from "effect"
44
+ *
45
+ * const fileLogger = Logger.logfmtLogger.pipe(
46
+ * PlatformLogger.toFile("/tmp/log.txt")
47
+ * )
48
+ * const LoggerLive = Logger.replaceScoped(Logger.defaultLogger, fileLogger).pipe(
49
+ * Layer.provide(NodeFileSystem.layer)
50
+ * )
51
+ *
52
+ * Effect.log("a").pipe(
53
+ * Effect.zipRight(Effect.log("b")),
54
+ * Effect.zipRight(Effect.log("c")),
55
+ * Effect.provide(LoggerLive),
56
+ * NodeRuntime.runMain
57
+ * )
58
+ */
36
59
  (
37
60
  path: string,
38
61
  options?:
@@ -45,6 +68,29 @@ export const toFile: {
45
68
  ): <Message>(
46
69
  self: Logger.Logger<Message, string>
47
70
  ) => Effect<Logger.Logger<Message, void>, PlatformError, Scope | FileSystem>
71
+ /**
72
+ * Create a Logger from another string Logger that writes to the specified file.
73
+ *
74
+ * @since 1.0.0
75
+ * @example
76
+ * import { PlatformLogger } from "@effect/platform"
77
+ * import { NodeFileSystem, NodeRuntime } from "@effect/platform-node"
78
+ * import { Effect, Layer, Logger } from "effect"
79
+ *
80
+ * const fileLogger = Logger.logfmtLogger.pipe(
81
+ * PlatformLogger.toFile("/tmp/log.txt")
82
+ * )
83
+ * const LoggerLive = Logger.replaceScoped(Logger.defaultLogger, fileLogger).pipe(
84
+ * Layer.provide(NodeFileSystem.layer)
85
+ * )
86
+ *
87
+ * Effect.log("a").pipe(
88
+ * Effect.zipRight(Effect.log("b")),
89
+ * Effect.zipRight(Effect.log("c")),
90
+ * Effect.provide(LoggerLive),
91
+ * NodeRuntime.runMain
92
+ * )
93
+ */
48
94
  <Message>(
49
95
  self: Logger.Logger<Message, string>,
50
96
  path: string,
package/src/Socket.ts CHANGED
@@ -253,6 +253,10 @@ export const toChannel = <IE>(
253
253
  * @category combinators
254
254
  */
255
255
  export const toChannelString: {
256
+ /**
257
+ * @since 1.0.0
258
+ * @category combinators
259
+ */
256
260
  (encoding?: string | undefined): <IE>(self: Socket) => Channel.Channel<
257
261
  Chunk.Chunk<string>,
258
262
  Chunk.Chunk<Uint8Array | string | CloseEvent>,
@@ -261,10 +265,11 @@ export const toChannelString: {
261
265
  void,
262
266
  unknown
263
267
  >
264
- <IE>(
265
- self: Socket,
266
- encoding?: string | undefined
267
- ): Channel.Channel<
268
+ /**
269
+ * @since 1.0.0
270
+ * @category combinators
271
+ */
272
+ <IE>(self: Socket, encoding?: string | undefined): Channel.Channel<
268
273
  Chunk.Chunk<string>,
269
274
  Chunk.Chunk<Uint8Array | string | CloseEvent>,
270
275
  SocketError | IE,
@@ -407,13 +412,15 @@ export const fromWebSocket = <R>(
407
412
  let open = false
408
413
 
409
414
  function onMessage(event: MessageEvent) {
410
- const result = handler(
411
- typeof event.data === "string"
412
- ? event.data
413
- : event.data instanceof Uint8Array
414
- ? event.data
415
- : new Uint8Array(event.data)
416
- )
415
+ if (event.data instanceof Blob) {
416
+ return Effect.promise(() =>
417
+ event.data.arrayBuffer() as Promise<ArrayBuffer>
418
+ ).pipe(
419
+ Effect.andThen((buffer) => handler(new Uint8Array(buffer))),
420
+ run
421
+ )
422
+ }
423
+ const result = handler(event.data)
417
424
  if (Effect.isEffect(result)) {
418
425
  run(result)
419
426
  }
@@ -476,8 +483,7 @@ export const fromWebSocket = <R>(
476
483
  })
477
484
  }) :
478
485
  Effect.try({
479
- try: () =>
480
- ws.send(chunk),
486
+ try: () => ws.send(chunk),
481
487
  catch: (cause) => new SocketGenericError({ reason: "Write", cause })
482
488
  })
483
489
  ),
@@ -79,9 +79,15 @@ export const addAll = (tranferables: Iterable<globalThis.Transferable>): Effect.
79
79
  * @category schema
80
80
  */
81
81
  export const schema: {
82
- <I>(
83
- f: (_: I) => Iterable<globalThis.Transferable>
84
- ): <A, R>(self: Schema.Schema<A, I, R>) => Schema.Schema<A, I, R>
82
+ /**
83
+ * @since 1.0.0
84
+ * @category schema
85
+ */
86
+ <I>(f: (_: I) => Iterable<globalThis.Transferable>): <A, R>(self: Schema.Schema<A, I, R>) => Schema.Schema<A, I, R>
87
+ /**
88
+ * @since 1.0.0
89
+ * @category schema
90
+ */
85
91
  <A, I, R>(
86
92
  self: Schema.Schema<A, I, R>,
87
93
  f: (_: I) => Iterable<globalThis.Transferable>
package/src/UrlParams.ts CHANGED
@@ -71,7 +71,15 @@ export const empty: UrlParams = []
71
71
  * @category combinators
72
72
  */
73
73
  export const getAll: {
74
+ /**
75
+ * @since 1.0.0
76
+ * @category combinators
77
+ */
74
78
  (key: string): (self: UrlParams) => ReadonlyArray<string>
79
+ /**
80
+ * @since 1.0.0
81
+ * @category combinators
82
+ */
75
83
  (self: UrlParams, key: string): ReadonlyArray<string>
76
84
  } = dual(
77
85
  2,
@@ -89,7 +97,15 @@ export const getAll: {
89
97
  * @category combinators
90
98
  */
91
99
  export const getFirst: {
100
+ /**
101
+ * @since 1.0.0
102
+ * @category combinators
103
+ */
92
104
  (key: string): (self: UrlParams) => Option.Option<string>
105
+ /**
106
+ * @since 1.0.0
107
+ * @category combinators
108
+ */
93
109
  (self: UrlParams, key: string): Option.Option<string>
94
110
  } = dual(2, (self: UrlParams, key: string): Option.Option<string> =>
95
111
  Option.map(
@@ -102,7 +118,15 @@ export const getFirst: {
102
118
  * @category combinators
103
119
  */
104
120
  export const getLast: {
121
+ /**
122
+ * @since 1.0.0
123
+ * @category combinators
124
+ */
105
125
  (key: string): (self: UrlParams) => Option.Option<string>
126
+ /**
127
+ * @since 1.0.0
128
+ * @category combinators
129
+ */
106
130
  (self: UrlParams, key: string): Option.Option<string>
107
131
  } = dual(2, (self: UrlParams, key: string): Option.Option<string> =>
108
132
  Option.map(
@@ -115,7 +139,15 @@ export const getLast: {
115
139
  * @category combinators
116
140
  */
117
141
  export const set: {
142
+ /**
143
+ * @since 1.0.0
144
+ * @category combinators
145
+ */
118
146
  (key: string, value: Coercible): (self: UrlParams) => UrlParams
147
+ /**
148
+ * @since 1.0.0
149
+ * @category combinators
150
+ */
119
151
  (self: UrlParams, key: string, value: Coercible): UrlParams
120
152
  } = dual(3, (self: UrlParams, key: string, value: Coercible): UrlParams =>
121
153
  Arr.append(
@@ -128,7 +160,15 @@ export const set: {
128
160
  * @category combinators
129
161
  */
130
162
  export const setAll: {
163
+ /**
164
+ * @since 1.0.0
165
+ * @category combinators
166
+ */
131
167
  (input: Input): (self: UrlParams) => UrlParams
168
+ /**
169
+ * @since 1.0.0
170
+ * @category combinators
171
+ */
132
172
  (self: UrlParams, input: Input): UrlParams
133
173
  } = dual(2, (self: UrlParams, input: Input): UrlParams => {
134
174
  const toSet = fromInput(input)
@@ -144,7 +184,15 @@ export const setAll: {
144
184
  * @category combinators
145
185
  */
146
186
  export const append: {
187
+ /**
188
+ * @since 1.0.0
189
+ * @category combinators
190
+ */
147
191
  (key: string, value: Coercible): (self: UrlParams) => UrlParams
192
+ /**
193
+ * @since 1.0.0
194
+ * @category combinators
195
+ */
148
196
  (self: UrlParams, key: string, value: Coercible): UrlParams
149
197
  } = dual(3, (self: UrlParams, key: string, value: Coercible): UrlParams =>
150
198
  Arr.append(
@@ -157,7 +205,15 @@ export const append: {
157
205
  * @category combinators
158
206
  */
159
207
  export const appendAll: {
208
+ /**
209
+ * @since 1.0.0
210
+ * @category combinators
211
+ */
160
212
  (input: Input): (self: UrlParams) => UrlParams
213
+ /**
214
+ * @since 1.0.0
215
+ * @category combinators
216
+ */
161
217
  (self: UrlParams, input: Input): UrlParams
162
218
  } = dual(2, (self: UrlParams, input: Input): UrlParams => Arr.appendAll(self, fromInput(input)))
163
219
 
@@ -166,7 +222,15 @@ export const appendAll: {
166
222
  * @category combinators
167
223
  */
168
224
  export const remove: {
225
+ /**
226
+ * @since 1.0.0
227
+ * @category combinators
228
+ */
169
229
  (key: string): (self: UrlParams) => UrlParams
230
+ /**
231
+ * @since 1.0.0
232
+ * @category combinators
233
+ */
170
234
  (self: UrlParams, key: string): UrlParams
171
235
  } = dual(2, (self: UrlParams, key: string): UrlParams => Arr.filter(self, ([k]) => k !== key))
172
236
 
@@ -33,6 +33,9 @@ abstract class BodyBase implements Body.HttpBody.Proto {
33
33
  this[TypeId] = TypeId
34
34
  }
35
35
  abstract toJSON(): unknown
36
+ [Inspectable.DenoInspectSymbol](): unknown {
37
+ return this.toJSON()
38
+ }
36
39
  [Inspectable.NodeInspectSymbol](): unknown {
37
40
  return this.toJSON()
38
41
  }