You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					88 lines
				
				2.2 KiB
			
		
		
			
		
	
	
					88 lines
				
				2.2 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								import { Readable } from 'stream';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								declare namespace getRawBody {
							 | 
						||
| 
								 | 
							
								  export type Encoding = string | true;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  export interface Options {
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * The expected length of the stream.
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    length?: number | string | null;
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * The byte limit of the body. This is the number of bytes or any string
							 | 
						||
| 
								 | 
							
								     * format supported by `bytes`, for example `1000`, `'500kb'` or `'3mb'`.
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    limit?: number | string | null;
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * The encoding to use to decode the body into a string. By default, a
							 | 
						||
| 
								 | 
							
								     * `Buffer` instance will be returned when no encoding is specified. Most
							 | 
						||
| 
								 | 
							
								     * likely, you want `utf-8`, so setting encoding to `true` will decode as
							 | 
						||
| 
								 | 
							
								     * `utf-8`. You can use any type of encoding supported by `iconv-lite`.
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    encoding?: Encoding | null;
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  export interface RawBodyError extends Error {
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * The limit in bytes.
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    limit?: number;
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * The expected length of the stream.
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    length?: number;
							 | 
						||
| 
								 | 
							
								    expected?: number;
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * The received bytes.
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    received?: number;
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * The encoding.
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    encoding?: string;
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * The corresponding status code for the error.
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    status: number;
							 | 
						||
| 
								 | 
							
								    statusCode: number;
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * The error type.
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    type: string;
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Gets the entire buffer of a stream either as a `Buffer` or a string.
							 | 
						||
| 
								 | 
							
								 * Validates the stream's length against an expected length and maximum
							 | 
						||
| 
								 | 
							
								 * limit. Ideal for parsing request bodies.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								declare function getRawBody(
							 | 
						||
| 
								 | 
							
								  stream: Readable,
							 | 
						||
| 
								 | 
							
								  callback: (err: getRawBody.RawBodyError, body: Buffer) => void
							 | 
						||
| 
								 | 
							
								): void;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								declare function getRawBody(
							 | 
						||
| 
								 | 
							
								  stream: Readable,
							 | 
						||
| 
								 | 
							
								  options: (getRawBody.Options & { encoding: getRawBody.Encoding }) | getRawBody.Encoding,
							 | 
						||
| 
								 | 
							
								  callback: (err: getRawBody.RawBodyError, body: string) => void
							 | 
						||
| 
								 | 
							
								): void;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								declare function getRawBody(
							 | 
						||
| 
								 | 
							
								  stream: Readable,
							 | 
						||
| 
								 | 
							
								  options: getRawBody.Options,
							 | 
						||
| 
								 | 
							
								  callback: (err: getRawBody.RawBodyError, body: Buffer) => void
							 | 
						||
| 
								 | 
							
								): void;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								declare function getRawBody(
							 | 
						||
| 
								 | 
							
								  stream: Readable,
							 | 
						||
| 
								 | 
							
								  options: (getRawBody.Options & { encoding: getRawBody.Encoding }) | getRawBody.Encoding
							 | 
						||
| 
								 | 
							
								): Promise<string>;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								declare function getRawBody(
							 | 
						||
| 
								 | 
							
								  stream: Readable,
							 | 
						||
| 
								 | 
							
								  options?: getRawBody.Options
							 | 
						||
| 
								 | 
							
								): Promise<Buffer>;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								export = getRawBody;
							 |