Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/npm/cli.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorKat Marchán <kzm@sykosomatic.org>2017-06-06 00:53:35 +0300
committerKat Marchán <kzm@sykosomatic.org>2017-06-06 00:53:35 +0300
commit662a15ab7e790e87f5e5a35252f05d5a4a0724a1 (patch)
tree33728d32ab9c55279fbae14cb713c4f0eb213b28 /lib
parent346cb006e7d0fab674e40c31cb47008bf36ee169 (diff)
doctor: new cacache sets content files to be read-only
Diffstat (limited to 'lib')
-rw-r--r--lib/doctor.js6
-rw-r--r--lib/doctor/check-files-permission.js6
2 files changed, 6 insertions, 6 deletions
diff --git a/lib/doctor.js b/lib/doctor.js
index 357ba91a5..95ede1bc8 100644
--- a/lib/doctor.js
+++ b/lib/doctor.js
@@ -39,9 +39,9 @@ function doctor (args, silent, cb) {
[getLatestNpmVersion],
[getLatestNodejsVersion, args['node-url']],
[getGitPath],
- [checkFilesPermission, npm.cache, 6],
- [checkFilesPermission, globalNodeModules, 4],
- [checkFilesPermission, localNodeModules, 6],
+ [checkFilesPermission, npm.cache, 4, 6],
+ [checkFilesPermission, globalNodeModules, 4, 4],
+ [checkFilesPermission, localNodeModules, 6, 6],
[verifyCachedFiles, path.join(npm.cache, '_cacache')]
]
diff --git a/lib/doctor/check-files-permission.js b/lib/doctor/check-files-permission.js
index 50014fd23..1cefb6e64 100644
--- a/lib/doctor/check-files-permission.js
+++ b/lib/doctor/check-files-permission.js
@@ -6,7 +6,7 @@ var log = require('npmlog')
var npm = require('../npm.js')
var fileCompletion = require('../utils/completion/file-completion.js')
-function checkFilesPermission (root, mask, cb) {
+function checkFilesPermission (root, fmask, dmask, cb) {
if (process.platform === 'win32') return cb(null, true)
getUid(npm.config.get('user'), npm.config.get('group'), function (e, uid, gid) {
var tracker = log.newItem('checkFilePermissions', 1)
@@ -37,10 +37,10 @@ function checkFilesPermission (root, mask, cb) {
fs.lstat(file, function (e, stat) {
tracker.completeWork(1)
if (e) return next(e)
- if (!stat.isFile()) return next()
+ if (!stat.isDirectory() && !stat.isFile()) return next()
// 6 = fs.constants.R_OK | fs.constants.W_OK
// constants aren't available on v4
- fs.access(file, 6, (err) => {
+ fs.access(file, stat.isFile() ? fmask : dmask, (err) => {
if (err) {
tracker.error('checkFilePermissions', `Missing permissions on ${file}`)
return next(new Error('Missing permissions for ' + file))