Forked from std/fetch
Public
Script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
import { API_URL } from "https://esm.town/v/std/API_URL";
/**
* Wraps the JavaScript Fetch function to anonymize where the request is
* coming from ([Docs ↗](https://docs.val.town/std/fetch))
*
* @param {string | URL | Request} input - The resource to fetch.
* @param {RequestInit} [requestInit] - Optional configuration data (HTTP
* method, headers, etc) ([Docs ↗](https://deno.land/api@v1.42.1?s=RequestInit))
*/
export async function fetch(input: string | URL | Request, requestInit?: RequestInit) {
const origReq = new Request(input, requestInit);
const url = new URL("/v1/fetch", API_URL);
url.searchParams.set("url", origReq.url);
const req = new Request(url, origReq);
req.headers.set("X-Valtown-Authorization", `Bearer ${Deno.env.get("valtown")}`);
return globalThis.fetch(req);
}
Val Town is a social website to write and deploy JavaScript.
Build APIs and schedule functions from your browser.
v10 was merged from the PR "Always create new `Request` instance taking int…" by vladimyr
April 4, 2024
The main comment is probably too long. Maybe we can link out to the full docs from the JSDdoc widget? That could be neat.
Also, include the params in the JSDoc string?
With params:
And we don't need to specify
RequestInit
's fields, since it has its own JSDocs:I tweaked it a bit
I think we should also consider adding the type (ie
string
orRequestInit
) in such a way that it shows up on hover or changing the product to render that info.