1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-12-22 07:14:47 -05:00
A modern runtime for JavaScript and TypeScript. https://deno.com/
Find a file
Andreu Botella 1563088f06
fix: a Request whose URL is a revoked blob URL should still fetch (#11947)
In the spec, a URL record has an associated "blob URL entry", which for
`blob:` URLs is populated during parsing to contain a reference to the
`Blob` object that backs that object URL. It is this blob URL entry that
the `fetch` API uses to resolve an object URL.

Therefore, since the `Request` constructor parses URL inputs, it will
have an associated blob URL entry which will be used when fetching, even
if the object URL has been revoked since the construction of the
`Request` object. (The `Request` constructor takes the URL as a string
and parses it, so the object URL must be live at the time it is called.)

This PR adds a new `blobFromObjectUrl` JS function (backed by a new
`op_blob_from_object_url` op) that, if the URL is a valid object URL,
returns a new `Blob` object whose parts are references to the same Rust
`BlobPart`s used by the original `Blob` object. It uses this function to
add a new `blobUrlEntry` field to inner requests, which will be `null`
or such a `Blob`, and then uses `Blob.prototype.stream()` as the
response's body. As a result of this, the `blob:` URL resolution from
`op_fetch` is now useless, and has been removed.
2021-09-08 11:29:21 +02:00
.cargo Statically link the C runtime library on Windows (#4469) 2020-03-23 20:31:29 +01:00
.devcontainer build: add devcontainer configuration (#11670) 2021-08-13 14:24:38 +02:00
.github chore(std/http): server module name migration (#11890) 2021-09-05 22:43:46 +02:00
bench_util chore: update dependencies (#11856) 2021-09-02 23:38:44 +02:00
cli feat: add URLPattern API (#11941) 2021-09-08 11:14:29 +02:00
core fix(ext/web): Format terminal DOMExceptions properly (#11834) 2021-09-06 22:59:20 +02:00
docs chore: move docs to separate repository 2021-07-20 16:25:36 +02:00
ext fix: a Request whose URL is a revoked blob URL should still fetch (#11947) 2021-09-08 11:29:21 +02:00
runtime feat: add URLPattern API (#11941) 2021-09-08 11:14:29 +02:00
test_ffi feat: ffi to replace plugins (#11152) 2021-08-06 23:28:10 +02:00
test_util feat(cli): Support Basic authentication in DENO_AUTH_TOKENS (#11910) 2021-09-08 06:18:11 +02:00
third_party@bc48d46314 chore: upgrade third_party for dprint 0.17 (#11930) 2021-09-06 12:44:07 -04:00
tools fix: a Request whose URL is a revoked blob URL should still fetch (#11947) 2021-09-08 11:29:21 +02:00
.dlint.json chore: upgrade dlint and run prefer-primordials rule (#11777) 2021-08-20 01:14:20 +02:00
.dprint.json chore: upgrade third_party for dprint 0.17 (#11930) 2021-09-06 12:44:07 -04:00
.editorconfig editorconfig: Don't insert final newline in .out files (#1686) 2019-02-07 11:31:49 -05:00
.gitattributes chore: move test files to testdata directory (#11601) 2021-08-11 10:20:47 -04:00
.gitignore tests: fix wpt epoch ci job (#10960) 2021-06-14 20:57:02 +02:00
.gitmodules tests: fix wpt epoch ci job (#10960) 2021-06-14 20:57:02 +02:00
.rustfmt.toml chore: format toml files internally (#11563) 2021-08-02 10:19:27 -04:00
Cargo.lock feat: add URLPattern API (#11941) 2021-09-08 11:14:29 +02:00
Cargo.toml chore(ext/webgpu): update wgpu to 0.10.0 (#11781) 2021-08-24 13:29:42 +02:00
CODE_OF_CONDUCT.md fix(tools): prettier formatting (#6206) 2020-06-09 17:50:41 +02:00
LICENSE.md update copyright to 2021 (#9081) 2021-01-10 21:59:07 -05:00
README.md docs(README): Change the logo to vector image (#11841) 2021-08-25 15:27:18 +02:00
Releases.md 1.13.2 (#11822) 2021-08-23 16:58:49 -04:00

Deno

Build Status - Cirrus Twitter handle Discord Chat

the deno mascot dinosaur standing in the rain

Deno is a simple, modern and secure runtime for JavaScript and TypeScript that uses V8 and is built in Rust.

Features

  • Secure by default. No file, network, or environment access, unless explicitly enabled.
  • Supports TypeScript out of the box.
  • Ships only a single executable file.
  • Built-in utilities like a dependency inspector (deno info) and a code formatter (deno fmt).
  • Set of reviewed standard modules that are guaranteed to work with Deno.

Install

Shell (Mac, Linux):

curl -fsSL https://deno.land/x/install/install.sh | sh

PowerShell (Windows):

iwr https://deno.land/x/install/install.ps1 -useb | iex

Homebrew (Mac):

brew install deno

Chocolatey (Windows):

choco install deno

Scoop (Windows):

scoop install deno

Build and install from source using Cargo:

cargo install deno --locked

See deno_install and releases for other options.

Getting Started

Try running a simple program:

deno run https://deno.land/std/examples/welcome.ts

Or a more complex one:

const listener = Deno.listen({ port: 8000 });
console.log("http://localhost:8000/");

for await (const conn of listener) {
  serve(conn);
}

async function serve(conn: Deno.Conn) {
  for await (const { respondWith } of Deno.serveHttp(conn)) {
    respondWith(new Response("Hello world"));
  }
}

You can find a deeper introduction, examples, and environment setup guides in the manual.

The complete API reference is available at the runtime documentation.

Contributing

We appreciate your help!

To contribute, please read our contributing instructions.