1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-11-25 15:29:32 -05:00

docs: use const assertion for PermissionDescriptor (#7733)

Fixes #7731
This commit is contained in:
Trivikram Kamat 2020-09-27 19:47:00 -07:00 committed by GitHub
parent 54d897c140
commit 1437838ea1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -16,26 +16,26 @@ On the CLI, read permission for `/foo/bar` is represented as
`--allow-read=/foo/bar`. In runtime JS, it is represented as the following: `--allow-read=/foo/bar`. In runtime JS, it is represented as the following:
```ts ```ts
const desc = { name: "read", path: "/foo/bar" }; const desc = { name: "read", path: "/foo/bar" } as const;
``` ```
Other examples: Other examples:
```ts ```ts
// Global write permission. // Global write permission.
const desc1 = { name: "write" }; const desc1 = { name: "write" } as const;
// Write permission to `$PWD/foo/bar`. // Write permission to `$PWD/foo/bar`.
const desc2 = { name: "write", path: "foo/bar" }; const desc2 = { name: "write", path: "foo/bar" } as const;
// Global net permission. // Global net permission.
const desc3 = { name: "net" }; const desc3 = { name: "net" } as const;
// Net permission to 127.0.0.1:8000. // Net permission to 127.0.0.1:8000.
const desc4 = { name: "net", url: "127.0.0.1:8000" }; const desc4 = { name: "net", url: "127.0.0.1:8000" } as const;
// High-resolution time permission. // High-resolution time permission.
const desc5 = { name: "hrtime" }; const desc5 = { name: "hrtime" } as const;
``` ```
### Query permissions ### Query permissions
@ -45,15 +45,15 @@ Check, by descriptor, if a permission is granted or not.
```ts ```ts
// deno run --unstable --allow-read=/foo main.ts // deno run --unstable --allow-read=/foo main.ts
const desc1 = { name: "read", path: "/foo" }; const desc1 = { name: "read", path: "/foo" } as const;
console.log(await Deno.permissions.query(desc1)); console.log(await Deno.permissions.query(desc1));
// PermissionStatus { state: "granted" } // PermissionStatus { state: "granted" }
const desc2 = { name: "read", path: "/foo/bar" }; const desc2 = { name: "read", path: "/foo/bar" } as const;
console.log(await Deno.permissions.query(desc2)); console.log(await Deno.permissions.query(desc2));
// PermissionStatus { state: "granted" } // PermissionStatus { state: "granted" }
const desc3 = { name: "read", path: "/bar" }; const desc3 = { name: "read", path: "/bar" } as const;
console.log(await Deno.permissions.query(desc3)); console.log(await Deno.permissions.query(desc3));
// PermissionStatus { state: "prompt" } // PermissionStatus { state: "prompt" }
``` ```
@ -82,13 +82,13 @@ _[stronger than](https://www.w3.org/TR/permissions/#ref-for-permissiondescriptor
More examples: More examples:
```ts ```ts
const desc1 = { name: "write" }; const desc1 = { name: "write" } as const;
// is stronger than // is stronger than
const desc2 = { name: "write", path: "/foo" }; const desc2 = { name: "write", path: "/foo" } as const;
const desc3 = { name: "net" }; const desc3 = { name: "net" } as const;
// is stronger than // is stronger than
const desc4 = { name: "net", url: "127.0.0.1:8000" }; const desc4 = { name: "net", url: "127.0.0.1:8000" } as const;
``` ```
### Request permissions ### Request permissions
@ -98,13 +98,13 @@ Request an ungranted permission from the user via CLI prompt.
```ts ```ts
// deno run --unstable main.ts // deno run --unstable main.ts
const desc1 = { name: "read", path: "/foo" }; const desc1 = { name: "read", path: "/foo" } as const;
const status1 = await Deno.permissions.request(desc1); const status1 = await Deno.permissions.request(desc1);
// ⚠️ Deno requests read access to "/foo". Grant? [g/d (g = grant, d = deny)] g // ⚠️ Deno requests read access to "/foo". Grant? [g/d (g = grant, d = deny)] g
console.log(status1); console.log(status1);
// PermissionStatus { state: "granted" } // PermissionStatus { state: "granted" }
const desc2 = { name: "read", path: "/bar" }; const desc2 = { name: "read", path: "/bar" } as const;
const status2 = await Deno.permissions.request(desc2); const status2 = await Deno.permissions.request(desc2);
// ⚠️ Deno requests read access to "/bar". Grant? [g/d (g = grant, d = deny)] d // ⚠️ Deno requests read access to "/bar". Grant? [g/d (g = grant, d = deny)] d
console.log(status2); console.log(status2);
@ -129,7 +129,7 @@ Downgrade a permission from "granted" to "prompt".
```ts ```ts
// deno run --unstable --allow-read=/foo main.ts // deno run --unstable --allow-read=/foo main.ts
const desc = { name: "read", path: "/foo" }; const desc = { name: "read", path: "/foo" } as const;
console.log(await Deno.permissions.revoke(desc)); console.log(await Deno.permissions.revoke(desc));
// PermissionStatus { state: "prompt" } // PermissionStatus { state: "prompt" }
``` ```
@ -140,7 +140,7 @@ one granted on the CLI?
```ts ```ts
// deno run --unstable --allow-read=/foo main.ts // deno run --unstable --allow-read=/foo main.ts
const desc = { name: "read", path: "/foo/bar" }; const desc = { name: "read", path: "/foo/bar" } as const;
console.log(await Deno.permissions.revoke(desc)); console.log(await Deno.permissions.revoke(desc));
// PermissionStatus { state: "granted" } // PermissionStatus { state: "granted" }
``` ```
@ -177,11 +177,11 @@ whichever _explicitly granted permission descriptor_ is _stronger than_ `desc`.
```ts ```ts
// deno run --unstable --allow-read=/foo main.ts // deno run --unstable --allow-read=/foo main.ts
const desc = { name: "read", path: "/foo/bar" }; const desc = { name: "read", path: "/foo/bar" } as const;
console.log(await Deno.permissions.revoke(desc)); // Insufficient. console.log(await Deno.permissions.revoke(desc)); // Insufficient.
// PermissionStatus { state: "granted" } // PermissionStatus { state: "granted" }
const strongDesc = { name: "read", path: "/foo" }; const strongDesc = { name: "read", path: "/foo" } as const;
await Deno.permissions.revoke(strongDesc); // Good. await Deno.permissions.revoke(strongDesc); // Good.
console.log(await Deno.permissions.query(desc)); console.log(await Deno.permissions.query(desc));