2019-03-04 17:04:19 +01:00
|
|
|
// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
|
2019-09-02 17:07:11 -04:00
|
|
|
import * as dispatch from "./dispatch.ts";
|
|
|
|
import { sendSync } from "./dispatch_json.ts";
|
2019-03-04 17:04:19 +01:00
|
|
|
|
2019-10-28 00:22:53 +09:00
|
|
|
/** Permissions as granted by the caller
|
|
|
|
* See: https://w3c.github.io/permissions/#permission-registry
|
|
|
|
*/
|
|
|
|
export type PermissionName =
|
|
|
|
| "read"
|
|
|
|
| "write"
|
|
|
|
| "net"
|
|
|
|
| "env"
|
|
|
|
| "run"
|
|
|
|
| "hrtime";
|
|
|
|
// NOTE: Keep in sync with cli/permissions.rs
|
2019-03-04 17:04:19 +01:00
|
|
|
|
2019-10-28 00:22:53 +09:00
|
|
|
/** https://w3c.github.io/permissions/#status-of-a-permission */
|
|
|
|
export type PermissionState = "granted" | "denied" | "prompt";
|
2019-03-04 17:04:19 +01:00
|
|
|
|
2019-10-28 00:22:53 +09:00
|
|
|
interface RunPermissionDescriptor {
|
|
|
|
name: "run";
|
|
|
|
}
|
|
|
|
interface ReadWritePermissionDescriptor {
|
|
|
|
name: "read" | "write";
|
|
|
|
path?: string;
|
|
|
|
}
|
|
|
|
interface NetPermissionDescriptor {
|
|
|
|
name: "net";
|
|
|
|
url?: string;
|
|
|
|
}
|
|
|
|
interface EnvPermissionDescriptor {
|
|
|
|
name: "env";
|
2019-03-10 04:30:38 +11:00
|
|
|
}
|
2019-10-28 00:22:53 +09:00
|
|
|
interface HrtimePermissionDescriptor {
|
|
|
|
name: "hrtime";
|
|
|
|
}
|
|
|
|
/** See: https://w3c.github.io/permissions/#permission-descriptor */
|
|
|
|
type PermissionDescriptor =
|
|
|
|
| RunPermissionDescriptor
|
|
|
|
| ReadWritePermissionDescriptor
|
|
|
|
| NetPermissionDescriptor
|
|
|
|
| EnvPermissionDescriptor
|
|
|
|
| HrtimePermissionDescriptor;
|
2019-03-10 04:30:38 +11:00
|
|
|
|
2019-10-28 00:22:53 +09:00
|
|
|
/** https://w3c.github.io/permissions/#permissionstatus */
|
|
|
|
export class PermissionStatus {
|
|
|
|
constructor(public state: PermissionState) {}
|
|
|
|
// TODO(kt3k): implement onchange handler
|
|
|
|
}
|
|
|
|
|
|
|
|
export class Permissions {
|
|
|
|
/** Queries the permission.
|
|
|
|
* const status = await Deno.permissions.query({ name: "read", path: "/etc" });
|
|
|
|
* if (status.state === "granted") {
|
|
|
|
* file = await Deno.readFile("/etc/passwd");
|
|
|
|
* }
|
|
|
|
*/
|
|
|
|
async query(desc: PermissionDescriptor): Promise<PermissionStatus> {
|
|
|
|
const { state } = sendSync(dispatch.OP_QUERY_PERMISSION, desc);
|
|
|
|
return new PermissionStatus(state);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Revokes the permission.
|
|
|
|
* const status = await Deno.permissions.revoke({ name: "run" });
|
|
|
|
* assert(status.state !== "granted")
|
|
|
|
*/
|
|
|
|
async revoke(desc: PermissionDescriptor): Promise<PermissionStatus> {
|
|
|
|
const { state } = sendSync(dispatch.OP_REVOKE_PERMISSION, desc);
|
|
|
|
return new PermissionStatus(state);
|
|
|
|
}
|
2019-11-12 00:33:29 +09:00
|
|
|
|
|
|
|
/** Requests the permission.
|
|
|
|
* const status = await Deno.permissions.request({ name: "env" });
|
|
|
|
* if (status.state === "granted") {
|
|
|
|
* console.log(Deno.homeDir());
|
|
|
|
* } else {
|
|
|
|
* console.log("'env' permission is denied.");
|
|
|
|
* }
|
|
|
|
*/
|
|
|
|
async request(desc: PermissionDescriptor): Promise<PermissionStatus> {
|
|
|
|
const { state } = sendSync(dispatch.OP_REQUEST_PERMISSION, desc);
|
|
|
|
return new PermissionStatus(state);
|
|
|
|
}
|
2019-03-04 17:04:19 +01:00
|
|
|
}
|
2019-10-28 00:22:53 +09:00
|
|
|
|
|
|
|
export const permissions = new Permissions();
|