From dbaa90af1ab5cad06f03deef422c2216397498f1 Mon Sep 17 00:00:00 2001 From: Santino Date: Wed, 20 Jul 2022 21:23:04 +0200 Subject: [PATCH] feat(client): Accept `referrer` and `referrerPolicy` fetch options (#32) --- docs/interfaces/ClientOptions.md | 36 ++++++++++++++++++++++++++++ src/client.ts | 40 +++++++++++++++++++++++++++++++- 2 files changed, 75 insertions(+), 1 deletion(-) diff --git a/docs/interfaces/ClientOptions.md b/docs/interfaces/ClientOptions.md index 58f34ddb..2890eb4b 100644 --- a/docs/interfaces/ClientOptions.md +++ b/docs/interfaces/ClientOptions.md @@ -21,6 +21,8 @@ - [lazyCloseTimeout](ClientOptions.md#lazyclosetimeout) - [onMessage](ClientOptions.md#onmessage) - [onNonLazyError](ClientOptions.md#onnonlazyerror) +- [referrer](ClientOptions.md#referrer) +- [referrerPolicy](ClientOptions.md#referrerpolicy) - [retry](ClientOptions.md#retry) - [retryAttempts](ClientOptions.md#retryattempts) - [singleConnection](ClientOptions.md#singleconnection) @@ -192,6 +194,40 @@ console.error ___ +### referrer + +• `Optional` **referrer**: `string` + +A string specifying the referrer of the request. This can be a same-origin URL, about:client, or an empty string. + +**`Default`** + +undefined + +___ + +### referrerPolicy + +• `Optional` **referrerPolicy**: ``"same-origin"`` \| ``"no-referrer"`` \| ``"no-referrer-when-downgrade"`` \| ``"origin"`` \| ``"strict-origin"`` \| ``"origin-when-cross-origin"`` \| ``"strict-origin-when-cross-origin"`` \| ``"unsafe-url"`` + +Specifies the referrer policy to use for the request. + +Possible options are: + - `no-referrer`: Does not send referrer information along with requests to any origin. + - `no-referrer-when-downgrade`: Sends full referrerURL for requests: whose referrerURL and current URL are both potentially trustworthy URLs, or whose referrerURL is a non-potentially trustworthy URL. + - `same-origin`: Sends full referrerURL as referrer information when making same-origin-referrer requests. + - `origin`: Sends only the ASCII serialization of the request’s referrerURL when making both same-origin-referrer requests and cross-origin-referrer requests. + - `strict-origin`: Sends the ASCII serialization of the origin of the referrerURL for requests: whose referrerURL and current URL are both potentially trustworthy URLs, or whose referrerURL is a non-potentially trustworthy URL + - `origin-when-cross-origin`: Sends full referrerURL when making same-origin-referrer requests, and only the ASCII serialization of the origin of the request’s referrerURL is sent when making cross-origin-referrer requests + - `strict-origin-when-cross-origin`: Sends full referrerURL when making same-origin-referrer requests, and only the ASCII serialization of the origin of the request’s referrerURL when making cross-origin-referrer requests: whose referrerURL and current URL are both potentially trustworthy URLs, or whose referrerURL is a non-potentially trustworthy URL. + - `unsafe-url`: Sends full referrerURL along for both same-origin-referrer requests and cross-origin-referrer requests. + +**`Default`** + +undefined + +___ + ### retry • `Optional` **retry**: (`retries`: `number`) => `Promise`<`void`\> diff --git a/src/client.ts b/src/client.ts index b5772f6a..d7a78cbd 100644 --- a/src/client.ts +++ b/src/client.ts @@ -99,6 +99,28 @@ export interface ClientOptions { * @default same-origin */ credentials?: 'omit' | 'same-origin' | 'include'; + /** + * A string specifying the referrer of the request. This can be a same-origin URL, about:client, or an empty string. + * + * @default undefined + */ + referrer?: string; + /** + * Specifies the referrer policy to use for the request. + * + * Possible options are: + * - `no-referrer`: Does not send referrer information along with requests to any origin. + * - `no-referrer-when-downgrade`: Sends full referrerURL for requests: whose referrerURL and current URL are both potentially trustworthy URLs, or whose referrerURL is a non-potentially trustworthy URL. + * - `same-origin`: Sends full referrerURL as referrer information when making same-origin-referrer requests. + * - `origin`: Sends only the ASCII serialization of the request’s referrerURL when making both same-origin-referrer requests and cross-origin-referrer requests. + * - `strict-origin`: Sends the ASCII serialization of the origin of the referrerURL for requests: whose referrerURL and current URL are both potentially trustworthy URLs, or whose referrerURL is a non-potentially trustworthy URL + * - `origin-when-cross-origin`: Sends full referrerURL when making same-origin-referrer requests, and only the ASCII serialization of the origin of the request’s referrerURL is sent when making cross-origin-referrer requests + * - `strict-origin-when-cross-origin`: Sends full referrerURL when making same-origin-referrer requests, and only the ASCII serialization of the origin of the request’s referrerURL when making cross-origin-referrer requests: whose referrerURL and current URL are both potentially trustworthy URLs, or whose referrerURL is a non-potentially trustworthy URL. + * - `unsafe-url`: Sends full referrerURL along for both same-origin-referrer requests and cross-origin-referrer requests. + * + * @default undefined + */ + referrerPolicy?: 'no-referrer' | 'no-referrer-when-downgrade' | 'same-origin' | 'origin' | 'strict-origin' | 'origin-when-cross-origin' | 'strict-origin-when-cross-origin' | 'unsafe-url'; /** * HTTP headers to pass along the request. * @@ -234,6 +256,8 @@ export function createClient( ); }, credentials = 'same-origin', + referrer, + referrerPolicy, onMessage, } = options; const fetchFn = (options.fetchFn || fetch) as typeof fetch; @@ -322,6 +346,8 @@ export function createClient( signal: connCtrl.signal, method: 'PUT', credentials, + referrer, + referrerPolicy, headers, }); } catch (err) { @@ -336,6 +362,8 @@ export function createClient( signal: connCtrl.signal, headers, credentials, + referrer, + referrerPolicy, url, fetchFn, onMessage, @@ -427,6 +455,8 @@ export function createClient( signal: control.signal, headers, credentials, + referrer, + referrerPolicy, url, body: JSON.stringify(request), fetchFn, @@ -491,6 +521,8 @@ export function createClient( signal: control.signal, method: 'POST', credentials, + referrer, + referrerPolicy, headers, body: JSON.stringify(request), }); @@ -511,6 +543,8 @@ export function createClient( signal: control.signal, method: 'DELETE', credentials, + referrer, + referrerPolicy, headers, }); } catch (err) { @@ -647,6 +681,8 @@ interface ConnectOptions { signal: AbortSignal; url: string; credentials: 'omit' | 'same-origin' | 'include'; + referrer?: string; + referrerPolicy?: 'no-referrer' | 'no-referrer-when-downgrade' | 'same-origin' | 'origin' | 'strict-origin' | 'origin-when-cross-origin' | 'strict-origin-when-cross-origin' | 'unsafe-url'; headers?: Record | undefined; body?: string; fetchFn: typeof fetch; @@ -658,7 +694,7 @@ interface ConnectOptions { async function connect( options: ConnectOptions, ): Promise { - const { signal, url, credentials, headers, body, fetchFn, onMessage } = + const { signal, url, credentials, headers, body, referrer, referrerPolicy, fetchFn, onMessage } = options; const waiting: { @@ -674,6 +710,8 @@ async function connect( signal, method: body ? 'POST' : 'GET', credentials, + referrer, + referrerPolicy, headers: { ...headers, accept: 'text/event-stream',