From ad0072abfaa1d9fc948244abd8876844c8f145d2 Mon Sep 17 00:00:00 2001 From: cjihrig Date: Thu, 30 Aug 2018 09:55:11 -0400 Subject: [PATCH] os: don't use getCheckedFunction() in userInfo() os.userInfo() takes an optional object as its first argument. getCheckedFunction() adds a context object to the argument list passed to the binding layer. The context object has the potential to confuse the binding layer, particularly if an error occurs. This commit makes userInfo() explicitly call into the binding layer with two arguments. PR-URL: https://github.com/nodejs/node/pull/22609 Refs: https://github.com/nodejs/node/pull/22599 Reviewed-By: Daniel Bevenius Reviewed-By: Anna Henningsen Reviewed-By: Ruben Bridgewater Reviewed-By: Luigi Pinca --- lib/os.js | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/lib/os.js b/lib/os.js index 09a70d2f7b19e5..ace39c8e120397 100644 --- a/lib/os.js +++ b/lib/os.js @@ -40,7 +40,7 @@ const { getOSType: _getOSType, getPriority: _getPriority, getTotalMem, - getUserInfo: _getUserInfo, + getUserInfo, getUptime, isBigEndian, setPriority: _setPriority @@ -64,7 +64,6 @@ const getHostname = getCheckedFunction(_getHostname); const getInterfaceAddresses = getCheckedFunction(_getInterfaceAddresses); const getOSRelease = getCheckedFunction(_getOSRelease); const getOSType = getCheckedFunction(_getOSType); -const getUserInfo = getCheckedFunction(_getUserInfo); getFreeMem[Symbol.toPrimitive] = () => getFreeMem(); getHostname[Symbol.toPrimitive] = () => getHostname(); @@ -239,6 +238,19 @@ function getPriority(pid) { return priority; } +function userInfo(options) { + if (typeof options !== 'object') + options = null; + + const ctx = {}; + const user = getUserInfo(options, ctx); + + if (user === undefined) + throw new ERR_SYSTEM_ERROR(ctx); + + return user; +} + module.exports = { arch, cpus, @@ -255,7 +267,7 @@ module.exports = { tmpdir, totalmem: getTotalMem, type: getOSType, - userInfo: getUserInfo, + userInfo, uptime: getUptime, // Deprecated APIs