mockttp
Version:
Mock HTTP server for testing HTTP clients and stubbing webservices
56 lines • 3.46 kB
TypeScript
import { Headers, OngoingResponse, RawHeaders } from "../types";
export declare const findRawHeader: (rawHeaders: RawHeaders, targetKey: string) => [key: string, value: string] | undefined;
export declare const getHeaderValue: (headers: Headers | RawHeaders, targetKey: Lowercase<string>) => string | undefined;
export declare const findRawHeaderIndex: (rawHeaders: RawHeaders, targetKey: string) => number;
export declare const findRawHeaders: (rawHeaders: RawHeaders, targetKey: string) => [key: string, value: string][];
/**
* Return node's _very_ raw headers ([k, v, k, v, ...]) into our slightly more convenient
* pairwise tuples [[k, v], [k, v], ...] RawHeaders structure.
*/
export declare function pairFlatRawHeaders(flatRawHeaders: string[]): RawHeaders;
export declare function flattenPairedRawHeaders(rawHeaders: RawHeaders): string[];
/**
* Take a raw headers, and turn them into headers, but without some of Node's concessions
* to ease of use, i.e. keeping multiple values as arrays.
*
* This lowercases all names along the way, to provide a convenient header API for most
* downstream use cases, and to match Node's own behaviour.
*/
export declare function rawHeadersToObject(rawHeaders: RawHeaders): Headers;
/**
* Take raw headers, and turn them into headers just like `rawHeadersToObject` but
* also preserves case en route.
*
* This is separated because our public APIs should _not_ do this, but there's a few
* internal use cases where we want to, notably including passing headers to WS which
* only accepts a headers object when sending upstream requests, but does preserve
* case from the object.
*/
export declare function rawHeadersToObjectPreservingCase(rawHeaders: RawHeaders): Headers;
export declare function objectHeadersToRaw(headers: Headers): RawHeaders;
export declare function objectHeadersToFlat(headers: Headers): string[];
/**
* Combine the given headers with the raw headers, preserving the raw header details where
* possible. Headers keys that exist in the raw headers (case insensitive) will be overridden,
* while undefined header values will remove the header from the raw headers entirely.
*
* When proxying we often have raw received headers that we want to forward upstream exactly
* as they were received, but we also want to add or modify a subset of those headers. This
* method carefully does that - preserving everything that isn't actively modified as-is.
*/
export declare function updateRawHeaders(rawHeaders: RawHeaders, headers: Headers): [key: string, value: string][];
export declare function h2HeadersToH1(h2Headers: RawHeaders, method: string): RawHeaders;
export declare function h1HeadersToH2(headers: RawHeaders): RawHeaders;
export declare function dropDefaultHeaders(response: OngoingResponse): void;
export declare function validateHeader(name: string, value: string | string[]): boolean;
/**
* Set the value of a given header, overwriting it if present or otherwise adding it as a new header.
*
* For header objects, this overwrites all values. For raw headers, this overwrites the last value, so
* if multiple values are present others may remain. In general you probably don't want to use this
* for headers that could legally have multiple values present.
*/
export declare const setHeaderValue: (headers: Headers | RawHeaders, headerKey: string, headerValue: string, options?: {
prepend?: true;
}) => void;
//# sourceMappingURL=header-utils.d.ts.map