diff options
author | Luca Casonato <lucacasonato@yahoo.com> | 2020-05-07 00:21:13 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-05-06 18:21:13 -0400 |
commit | 34ec3b225425cecdccf754fbc87f4a8f3728890d (patch) | |
tree | 35db52bf25ccf64425692116197df61a69ea8838 /docs/examples/permissions.md | |
parent | 846c049c9b3ab36d0893292a204c4d0a18de4c8e (diff) |
Multi page manual (#5110)
Diffstat (limited to 'docs/examples/permissions.md')
-rw-r--r-- | docs/examples/permissions.md | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/docs/examples/permissions.md b/docs/examples/permissions.md new file mode 100644 index 000000000..7d404d5fc --- /dev/null +++ b/docs/examples/permissions.md @@ -0,0 +1,28 @@ +## Inspecting and revoking permissions + +> This program makes use of an unstable Deno feature. Learn more about +> [unstable features](../../runtime/unstable). + +Sometimes a program may want to revoke previously granted permissions. When a +program, at a later stage, needs those permissions, it will fail. + +```ts +// lookup a permission +const status = await Deno.permissions.query({ name: "write" }); +if (status.state !== "granted") { + throw new Error("need write permission"); +} + +const log = await Deno.open("request.log", "a+"); + +// revoke some permissions +await Deno.permissions.revoke({ name: "read" }); +await Deno.permissions.revoke({ name: "write" }); + +// use the log file +const encoder = new TextEncoder(); +await log.write(encoder.encode("hello\n")); + +// this will fail. +await Deno.remove("request.log"); +``` |