2024-01-01 21:11:32 +00:00
|
|
|
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
2023-09-13 08:21:52 +00:00
|
|
|
// This module is browser compatible.
|
|
|
|
|
|
|
|
import { toText } from "./to_text.ts";
|
|
|
|
|
2023-12-04 06:12:52 +00:00
|
|
|
/**
|
|
|
|
* Converts a JSON-formatted {@linkcode ReadableSteam} of strings or
|
|
|
|
* {@linkcode Uint8Array}s to an object. Works the same as
|
|
|
|
* {@linkcode Response.json}.
|
|
|
|
*
|
2024-05-28 01:27:40 +00:00
|
|
|
* @param readableStream A `ReadableStream` whose chunks compose a JSON.
|
|
|
|
* @returns A promise that resolves to the parsed JSON.
|
|
|
|
*
|
|
|
|
* @example Basic usage
|
2023-12-04 06:12:52 +00:00
|
|
|
* ```ts
|
2024-04-29 02:57:30 +00:00
|
|
|
* import { toJson } from "@std/streams/to-json";
|
2024-05-28 01:27:40 +00:00
|
|
|
* import { assertEquals } from "@std/assert/assert-equals";
|
2023-12-04 06:12:52 +00:00
|
|
|
*
|
2024-05-28 01:27:40 +00:00
|
|
|
* const stream = ReadableStream.from([
|
|
|
|
* "[1, true",
|
|
|
|
* ', [], {}, "hello',
|
|
|
|
* '", null]',
|
|
|
|
* ]);
|
|
|
|
* const json = await toJson(stream);
|
|
|
|
* assertEquals(json, [1, true, [], {}, "hello", null]);
|
2023-12-04 06:12:52 +00:00
|
|
|
* ```
|
|
|
|
*/
|
2023-09-13 08:21:52 +00:00
|
|
|
export function toJson(
|
|
|
|
readableStream: ReadableStream,
|
|
|
|
): Promise<unknown> {
|
|
|
|
return toText(readableStream).then(JSON.parse);
|
|
|
|
}
|