通过bower访问$ HOME / .config $ HOME / .cache

时间:2015-06-01 19:56:14

标签: node.js npm bower post-install

我正在尝试找出全局安装StriderCD的最佳方法。我通过global-enabled fork of nvm安装了node和npm,并且所有路径都适用于其他版本,但是没有一个需要像这样的post安装。

我已尝试过sudo npm install -g strider并且只是在没有sudo的情况下以root身份安装,但在安装后的步骤中,我总是在.config和.cache文件夹中遇到EACCESS错误:

> strider@1.6.6 postinstall /usr/local/lib/node_modules/strider
> bower install --allow-root && npm run build

/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/mkdirp/index.js:89
                    throw err0;
                          ^
Error: EACCES, permission denied '/home/ubuntu/.config'

以root身份安装,root没有权限使用它自己的$ HOME目录,除非bower正在创建具有错误权限的dirs和文件,否则这是非常奇怪的。任何人都可以解释一下:

> strider@1.6.6 postinstall /usr/local/lib/node_modules/strider
> bower install --allow-root && npm run build

/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/configstore/index.js:56
        throw err;
              ^
Error: EACCES, permission denied '/root/.config/configstore/bower-github.yml'
You don't have access to this file.

    at Error (native)
    at Object.fs.openSync (evalmachine.<anonymous>:500:18)
    at Object.fs.readFileSync (evalmachine.<anonymous>:352:15)
    at Object.create.all.get (/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/configstore/index.js:34:29)
    at Object.Configstore (/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/configstore/index.js:27:44)
    at readCachedConfig (/usr/local/lib/node_modules/strider/node_modules/bower/lib/config.js:22:23)
    at defaultConfig (/usr/local/lib/node_modules/strider/node_modules/bower/lib/config.js:11:24)
    at Object.<anonymous> (/usr/local/lib/node_modules/strider/node_modules/bower/lib/index.js:40:32)
    at Module._compile (module.js:460:26)
    at Object.Module._extensions..js (module.js:478:10)

使用sudo作为ubuntu用户并尝试chmod -R 777 $HOME/.config我在$HOME/.cache上得到了同样的东西!叹息。

> strider@1.6.6 postinstall /usr/local/lib/node_modules/strider
> bower install --allow-root && npm run build

bower                           EACCES EACCES, permission denied '/home/ubuntu/.cache/bower/registry/bower.herokuapp.com/lookup'

Stack trace:
Error: EACCES, permission denied '/home/ubuntu/.cache/bower/registry/bower.herokuapp.com/lookup'
    at Error (native)
    at Object.fs.mkdirSync (fs.js:747:18)
    at Function.sync (/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/bower-registry-client/node_modules/mkdirp/index.js:55:12)
    at new Cache (/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/bower-registry-client/lib/util/Cache.js:21:16)
    at RegistryClient.<anonymous> (/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/bower-registry-client/lib/lookup.js:163:35)
    at Array.forEach (native)
    at RegistryClient.initCache (/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/bower-registry-client/lib/lookup.js:150:34)
    at RegistryClient._initCache (/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/bower-registry-client/Client.js:62:27)
    at new RegistryClient (/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/bower-registry-client/Client.js:16:10)
    at new PackageRepository (/usr/local/lib/node_modules/strider/node_modules/bower/lib/core/PackageRepository.js:17:28)

Console trace:
Error
    at StandardRenderer.error (/usr/local/lib/node_modules/strider/node_modules/bower/lib/renderers/StandardRenderer.js:82:37)
    at Logger.<anonymous> (/usr/local/lib/node_modules/strider/node_modules/bower/bin/bower:110:22)
    at Logger.emit (events.js:107:17)
    at Logger.emit (/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/bower-logger/lib/Logger.js:29:39)
    at /usr/local/lib/node_modules/strider/node_modules/bower/lib/commands/index.js:45:20
    at _rejected (/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/q/q.js:844:24)
    at /usr/local/lib/node_modules/strider/node_modules/bower/node_modules/q/q.js:870:30
    at Promise.when (/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/q/q.js:1122:31)
    at Promise.promise.promiseDispatch (/usr/local/lib/node_modules/strider/node_modules/bower/node_modules/q/q.js:788:41)
    at /usr/local/lib/node_modules/strider/node_modules/bower/node_modules/q/q.js:556:49
System info:
Bower version: 1.4.1
Node version: 0.12.4
OS: Linux 3.13.0-48-generic x64

为什么当我使用$HOME/.config并使用sudo安装时,bower坚持使用--global?有没有办法将此映射到不同的路径并使权限正确?当我su root -l安装时,为什么root无权访问文件或在其内部创建dirs自己的$HOME和/或$HOME/.config?非常混乱。

这是在全新更新的14.04 LTS AWS实例上。这个错误的根本原因是什么?我的设置导致了bower或Strider部分的问题或错误的配置?

1 个答案:

答案 0 :(得分:0)

您的文件系统的权限看起来很奇怪,应该进行调查和修复。

也就是说,第一个堆栈跟踪的重要部分是configstore,这是一个用于缓存或持久保存数据到磁盘的机器。不用说它会尝试写入这些位置。这是一个开始的地方。

权限问题在较新的conf模块的常见问题解答中被提及,尽管它似乎不适用于Linux。

  

在configstore中,配置存储在所有系统上的〜/ .config(主要是Linux约定)中,而conf存储在系统默认用户配置目录中。事实证明,〜/ .config目录在macOS和Windows上的权限通常不正确,这给用户带来了很多麻烦。

切换到conf会解决问题吗?也许,也许不是。对file an issue无伤害。这是一个非常简单的替代品。你当然可以在node_modules内部进行黑客攻击,以验证是否能为你修复它。

configstoreconf都尊重XDG_CONFIG_HOME envrionment变量。然而,他们在稍微不同的时间读取它,前者在模块require()时读取,后者在实例化其类时。

我们还应该挑战作为特定用户(root)运行的进程的假设,因为Node程序可以process.setuid(),这在命令行工具中相对常见。

我会修改正在运行的各种node_modules文件并将其洒在某些文件中......

console.log('User:', process.getuid());
console.log('Group:', process.getgid());
console.log('Effective user:', process.geteuid());
console.log('Effective group:', process.getegid());

这很有用,因为bowernpm可能会在不方便的时候降级权限。或者npm run build脚本中的某些内容正在这样做。

如果您看到用户或组在程序的整个生命周期中发生变化,那么这是一个很容易出错的漏洞区域。仔细检查打印的用户或组是否具有对失败路径的完全访问权限。根据正在进行的精确活动,可能需要对父目录执行(x)权限,直到文件系统的根目录。