Recommendations/best 自定义 node.js CLI 工具配置文件的实践:位置和命名?

Recommendations/best practices on custom node.js CLI tool config files: location & naming?

我会尽量让这个问题简短,但它分为两部分,请:

  1. nodejs/npm CLI 工具的配置文件应该保存在哪里?
  2. 应该叫什么?

假设我编写了一个 node.js CLI 工具,例如,它可以获取今天的天气并将其显示在终端中。我称之为weather-getter。请注意,主要目标是 而不是 以编程方式调用,而是像 BASH 一样输入终端。它旨在通过在全局安装后键入其简单名称来成为 运行,通过用户本地 /bin 中的目录成为 。 (安装不需要 Sudo。

该项目将通过 npm 正常安装。它可以通过如下参数接收邮政编码:

gavin@localhost:~$ weather-getter -z "12345"

好的,程序可以像这样正常工作。我的下一步是允许用户在 某处 保存配置文件,并从该配置文件中提取默认值。类似于 .vimrc 文件。此配置可能如下所示:

{
  "zipcode": "12345",
  "language": "en",
  "unit": "fahrenheit"
}

我想它应该以点开头。我还认为它应该位于 npm 模块安装中,而不是 ~/。或者我应该考虑使用 ~//etc/~/.config~/.local 像许多其他程序一样?节点程序是否应该尝试使用公共目录,例如 ~/.config/node/~/.config/npm/?如果文件在那里,它是否应该在没有点的情况下开始?

注意:我的问题不是关于 reading/writing 带有 node.js 的文件,只是关于配置位置和命名约定的建议。谢谢!

由于这是安装到系统路径中的通用 CLI 应用程序(恰好在 Node.js 中实现),您应该遵循为目标操作系统建立的最佳实践或规则。

Unix/Linux/OSX,相似

按优先顺序,这些将是(但不限于):

  • ~(用户的主文件夹)- 许多程序将用户级配置存储在它们的主目录中,通常在以点为前缀的文件中,后跟应用程序的名称(或类似名称) - 即 ~/.weather-getter

  • /usr/local/etc, /etc - 系统级配置文件。这些通常适用于系统中的所有用户,因此优先级低于主文件夹中的设置。这两个 etc 路径的区别通常是前者用于用户安装的程序,而后者用于系统级程序(对于使用 [=17= 的 Mac 用户尤其如此]).然而,这种区别并不总是得到尊重,因此应该检查两个位置的配置文件(最好使用具有较低优先级的 /etc 目录)。

  • 您的应用程序的根 - 这些应该是您的应用程序的默认设置,当没有找到用户或系统配置时的回退。

  • 如有需要,可考虑其他地点。

Windows

如果您的应用允许 GUI 或至少 CLI 配置管理,或者 Windows 注册表(例如,使用 winreg),这通常位于 %APPDATA% 目录中的某个位置。我个人对 Windows development/CLI 没有什么经验,所以我欢迎任何关于这个主题的进一步评论或回答。我相信使用用户的主文件夹也是可以接受的,只要文件可以被标记为隐藏(这样它就不会使视图混乱)。

一些一般注意事项

  • 许多 CLI 应用程序将其默认配置安装到上述位置之一,以便用户在配置您的应用程序时有一个良好的起点
  • 当存在多个配置文件时,您的配置选项的处理方式(它们是否按某种顺序合并?只使用一个?哪个优先?)完全取决于您,但您应该在您的文档,甚至可能在配置文件本身中提到它
  • 如果您的应用程序需要多个配置文件,最好将它们分组在自己的文件夹中

关于点文件的更新

某些文件或文件夹以点为前缀的原因是为了让用户无法正常查看它们(即当通过 GUI 浏览它们的主目录时)。因此,通常的做法是在用户通常操作的目录中存储配置文件时使用点前缀 file/folder 名称,但在系统级文件夹中存储配置文件时 这样做.