mirror of
https://github.com/denoland/std.git
synced 2024-11-21 12:40:03 +00:00
a04a2ed798
* fix(streams): strictly define `toJson()` and `toText()` input * fix
47 lines
1.5 KiB
TypeScript
47 lines
1.5 KiB
TypeScript
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
// This module is browser compatible.
|
|
|
|
import { toText } from "./to_text.ts";
|
|
|
|
/**
|
|
* Converts a
|
|
* {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON}-formatted
|
|
* {@linkcode ReadableSteam} of strings or {@linkcode Uint8Array}s to an object.
|
|
* Works the same as {@linkcode Response.json} and {@linkcode Request.json}, but
|
|
* also extends to support streams of strings.
|
|
*
|
|
* @param stream A `ReadableStream` whose chunks compose a JSON.
|
|
* @returns A promise that resolves to the parsed JSON.
|
|
*
|
|
* @example Usage with a stream of strings
|
|
* ```ts
|
|
* import { toJson } from "@std/streams/to-json";
|
|
* import { assertEquals } from "@std/assert";
|
|
*
|
|
* const stream = ReadableStream.from([
|
|
* "[1, true",
|
|
* ', [], {}, "hello',
|
|
* '", null]',
|
|
* ]);
|
|
* assertEquals(await toJson(stream), [1, true, [], {}, "hello", null]);
|
|
* ```
|
|
*
|
|
* @example Usage with a stream of `Uint8Array`s
|
|
* ```ts
|
|
* import { toJson } from "@std/streams/to-json";
|
|
* import { assertEquals } from "@std/assert";
|
|
*
|
|
* const stream = ReadableStream.from([
|
|
* "[1, true",
|
|
* ', [], {}, "hello',
|
|
* '", null]',
|
|
* ]).pipeThrough(new TextEncoderStream());
|
|
* assertEquals(await toJson(stream), [1, true, [], {}, "hello", null]);
|
|
* ```
|
|
*/
|
|
export function toJson(
|
|
stream: ReadableStream<string> | ReadableStream<Uint8Array>,
|
|
): Promise<unknown> {
|
|
return toText(stream).then(JSON.parse);
|
|
}
|