From f14faab356c3eb42d80b8080172a866fadb33cc9 Mon Sep 17 00:00:00 2001 From: Nitzan Uziely Date: Tue, 16 Feb 2021 15:18:51 +0200 Subject: [PATCH] fs: fix pre-aborted writeFile AbortSignal file leak Fix an issue in writeFile where a file is opened, and not closed if the abort signal is aborted after the file was opened but before writing began. --- lib/internal/fs/promises.js | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/lib/internal/fs/promises.js b/lib/internal/fs/promises.js index 6c39a13349d27b8..033dcd54ce9f78b 100644 --- a/lib/internal/fs/promises.js +++ b/lib/internal/fs/promises.js @@ -66,6 +66,7 @@ const { const { opendir } = require('internal/fs/dir'); const { parseFileMode, + validateAbortSignal, validateBoolean, validateBuffer, validateInteger, @@ -668,14 +669,16 @@ async function writeFile(path, data, options) { data = Buffer.from(data, options.encoding || 'utf8'); } + validateAbortSignal(options.signal); if (path instanceof FileHandle) return writeFileHandle(path, data, options.signal); - const fd = await open(path, flag, options.mode); if (options.signal?.aborted) { throw lazyDOMException('The operation was aborted', 'AbortError'); } - return PromisePrototypeFinally(writeFileHandle(fd, data), fd.close); + + const fd = await open(path, flag, options.mode); + return PromisePrototypeFinally(writeFileHandle(fd, data, options.signal), fd.close); } async function appendFile(path, data, options) { @@ -692,6 +695,10 @@ async function readFile(path, options) { if (path instanceof FileHandle) return readFileHandle(path, options); + if (options.signal?.aborted) { + throw lazyDOMException('The operation was aborted', 'AbortError'); + } + const fd = await open(path, flag, 0o666); return PromisePrototypeFinally(readFileHandle(fd, options), fd.close); }