aboutsummaryrefslogtreecommitdiff
path: root/lib/fs.js
diff options
context:
space:
mode:
authorJames M Snell <jasnell@gmail.com>2017-11-26 16:53:33 -0800
committerJames M Snell <jasnell@gmail.com>2017-12-13 13:26:47 -0800
commit82eb459e3f5bab86c6aa75eae41cb51da1c6e2f6 (patch)
tree5749a94ba819f859cb9ce6832da024aa984a26c3 /lib/fs.js
parent0a01aa8e946ee86199af56ff3eac9bae67235ca8 (diff)
downloadandroid-node-v8-82eb459e3f5bab86c6aa75eae41cb51da1c6e2f6.tar.gz
android-node-v8-82eb459e3f5bab86c6aa75eae41cb51da1c6e2f6.tar.bz2
android-node-v8-82eb459e3f5bab86c6aa75eae41cb51da1c6e2f6.zip
fs: move type checking for fs.fchown to js
PR-URL: https://github.com/nodejs/node/pull/17334 Reviewed-By: Refael Ackermann <refack@gmail.com> Reviewed-By: Timothy Gu <timothygu99@gmail.com> Reviewed-By: Jon Moss <me@jonathanmoss.me> Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Diffstat (limited to 'lib/fs.js')
-rw-r--r--lib/fs.js28
1 files changed, 27 insertions, 1 deletions
diff --git a/lib/fs.js b/lib/fs.js
index c105f5fb3a..f13488ba0e 100644
--- a/lib/fs.js
+++ b/lib/fs.js
@@ -1249,12 +1249,38 @@ if (constants.O_SYMLINK !== undefined) {
}
fs.fchown = function(fd, uid, gid, callback) {
- var req = new FSReqWrap();
+ if (!Number.isInteger(fd))
+ throw new errors.TypeError('ERR_INVALID_ARG_TYPE', 'fd', 'number');
+ if (fd < 0 || fd > 0xFFFFFFFF)
+ throw new errors.RangeError('ERR_OUT_OF_RANGE', 'fd');
+ if (!Number.isInteger(uid))
+ throw new errors.TypeError('ERR_INVALID_ARG_TYPE', 'uid', 'number');
+ if (uid < 0)
+ throw new errors.RangeError('ERR_OUT_OF_RANGE', 'uid');
+ if (!Number.isInteger(gid))
+ throw new errors.TypeError('ERR_INVALID_ARG_TYPE', 'gid', 'number');
+ if (gid < 0)
+ throw new errors.RangeError('ERR_OUT_OF_RANGE', 'gid');
+
+ const req = new FSReqWrap();
req.oncomplete = makeCallback(callback);
binding.fchown(fd, uid, gid, req);
};
fs.fchownSync = function(fd, uid, gid) {
+ if (!Number.isInteger(fd))
+ throw new errors.TypeError('ERR_INVALID_ARG_TYPE', 'fd', 'number');
+ if (fd < 0 || fd > 0xFFFFFFFF)
+ throw new errors.RangeError('ERR_OUT_OF_RANGE', 'fd');
+ if (!Number.isInteger(uid))
+ throw new errors.TypeError('ERR_INVALID_ARG_TYPE', 'uid', 'number');
+ if (uid < 0)
+ throw new errors.RangeError('ERR_OUT_OF_RANGE', 'uid');
+ if (!Number.isInteger(gid))
+ throw new errors.TypeError('ERR_INVALID_ARG_TYPE', 'gid', 'number');
+ if (gid < 0)
+ throw new errors.RangeError('ERR_OUT_OF_RANGE', 'gid');
+
return binding.fchown(fd, uid, gid);
};