From f0068773c9edd639e523da2424385842405f8539 Mon Sep 17 00:00:00 2001 From: Joseph Werle Date: Mon, 30 Oct 2023 11:57:07 -0400 Subject: [PATCH] refactor(fs/watch): validate path/id in 'fs.Watcher' --- api/README.md | 2 +- api/fs/dir.js | 4 ++-- api/fs/index.js | 2 +- api/fs/watcher.js | 8 ++++++++ api/index.d.ts | 4 ++-- 5 files changed, 14 insertions(+), 6 deletions(-) diff --git a/api/README.md b/api/README.md index 0932c5b26c..5318814786 100644 --- a/api/README.md +++ b/api/README.md @@ -868,7 +868,7 @@ Chages ownership of link at `path` with `uid` and `gid. ## [`link(src, dest, )`](https://github.com/socketsupply/socket/blob/master/api/fs/index.js#L368) -Creates a link to `dest` from `dest`. +Creates a link to `dest` from `src`. | Argument | Type | Default | Optional | Description | | :--- | :--- | :---: | :---: | :--- | diff --git a/api/fs/dir.js b/api/fs/dir.js index f1193ee14e..551dc1674a 100644 --- a/api/fs/dir.js +++ b/api/fs/dir.js @@ -70,12 +70,12 @@ export class Dir { } /** - * `true` if closeing, otherwise `false`. + * `true` if closing, otherwise `false`. * @ignore * @type {boolean} */ get closing () { - return Boolean(this.handle?.closig) + return Boolean(this.handle?.closing) } /** diff --git a/api/fs/index.js b/api/fs/index.js index 1b13910118..8f7dab12e2 100644 --- a/api/fs/index.js +++ b/api/fs/index.js @@ -360,7 +360,7 @@ export function lchown (path, uid, gid, callback) { } /** - * Creates a link to `dest` from `dest`. + * Creates a link to `dest` from `src`. * @param {string} src * @param {string} dest * @param {function} diff --git a/api/fs/watcher.js b/api/fs/watcher.js index 120d675083..502e71baf4 100644 --- a/api/fs/watcher.js +++ b/api/fs/watcher.js @@ -1,4 +1,5 @@ import { EventEmitter } from '../events.js' +import { FileHandle } from './handle.js' import { AbortError } from '../errors.js' import { rand64 } from '../crypto.js' import { Buffer } from '../buffer.js' @@ -32,6 +33,13 @@ function encodeFilename (watcher, filename) { * @return {Promise} */ async function start (watcher) { + // throws if not accessible + await FileHandle.access(watcher.path) + + if (!watcher.id || typeof watcher.id !== 'string') { + throw new TypeError('Expectig fs.Watcher to have a id.') + } + const result = await ipc.send('fs.watch', { path: watcher.path, id: watcher.id diff --git a/api/index.d.ts b/api/index.d.ts index 3b2ef83396..2a2a197833 100644 --- a/api/index.d.ts +++ b/api/index.d.ts @@ -2286,7 +2286,7 @@ declare module "socket:fs/dir" { */ get closed(): boolean; /** - * `true` if closeing, otherwise `false`. + * `true` if closing, otherwise `false`. * @ignore * @type {boolean} */ @@ -2955,7 +2955,7 @@ declare module "socket:fs/index" { */ export function lchown(path: string, uid: number, gid: number, callback: Function): void; /** - * Creates a link to `dest` from `dest`. + * Creates a link to `dest` from `src`. * @param {string} src * @param {string} dest * @param {function}