权限

MiMo Code 使用 permission 配置来决定某个操作是否应自动运行、提示你审批,还是被阻止。

操作

每条权限规则解析为以下之一:

  • "allow" — 无需审批直接运行
  • "ask" — 提示审批
  • "deny" — 阻止该操作

配置

你可以全局设置权限(使用 *),并覆盖特定工具的权限。

1{
2  "$schema": "https://mimo.xiaomi.com//config.json",
3  "permission": {
4    "*": "ask",
5    "bash": "allow",
6    "edit": "deny"
7  }
8}

你还可以一次性设置所有权限:

1{
2  "$schema": "https://mimo.xiaomi.com//config.json",
3  "permission": "allow"
4}

细粒度规则(对象语法)

对于大多数权限,你可以使用对象来根据工具输入应用不同的操作。

1{
2  "$schema": "https://mimo.xiaomi.com//config.json",
3  "permission": {
4    "bash": {
5      "*": "ask",
6      "git *": "allow",
7      "npm *": "allow",
8      "rm *": "deny",
9      "grep *": "allow"
10    },
11    "edit": {
12      "*": "deny",
13      "packages/web/src/content/docs/*.mdx": "allow"
14    }
15  }
16}

规则通过模式匹配进行评估,最后匹配的规则优先。常见做法是将通配的 "*" 规则放在最前面,更具体的规则放在后面。

通配符

权限模式使用简单的通配符匹配:

  • * 匹配零个或多个任意字符
  • ? 精确匹配一个字符
  • 所有其他字符按字面值匹配

主目录展开

你可以在模式开头使用 ~$HOME 来引用你的主目录。这对于 external_directory 规则特别有用。

  • ~/projects/* -> /Users/username/projects/*
  • $HOME/projects/* -> /Users/username/projects/*
  • ~ -> /Users/username

外部目录

使用 external_directory 允许工具调用访问 MiMo Code 启动时工作目录之外的路径。这适用于任何接受路径作为输入的工具(例如 readeditglobgrep 以及许多 bash 命令)。

主目录展开(如 ~/...)仅影响模式的书写方式。它不会将外部路径纳入当前工作空间,因此工作目录之外的路径仍然必须通过 external_directory 来允许。

例如,以下配置允许访问 ~/projects/personal/ 下的所有内容:

1{
2  "$schema": "https://mimo.xiaomi.com//config.json",
3  "permission": {
4    "external_directory": {
5      "~/projects/personal/**": "allow"
6    }
7  }
8}

此处允许的任何目录都会继承与当前工作空间相同的默认值。由于 read 默认为 allowexternal_directory 下的条目也允许读取,除非另行覆盖。当需要在这些路径中限制某个工具时,请添加显式规则,例如在保留读取的同时阻止编辑:

1{
2  "$schema": "https://mimo.xiaomi.com//config.json",
3  "permission": {
4    "external_directory": {
5      "~/projects/personal/**": "allow"
6    },
7    "edit": {
8      "~/projects/personal/**": "deny"
9    }
10  }
11}

请将列表限定在受信任的路径上,并根据需要为其他工具(例如 bash)叠加额外的允许或拒绝规则。

可用权限

MiMo Code 的权限以工具名称为键,外加几个安全防护项:

  • read — 读取文件(匹配文件路径)
  • edit — 所有文件修改(涵盖 editwritepatchmultiedit
  • glob — 文件通配(匹配通配模式)
  • grep — 内容搜索(匹配正则表达式模式)
  • bash — 运行 shell 命令(匹配解析后的命令,如 git status --porcelain
  • task — 启动子代理(匹配子代理类型)
  • skill — 加载技能(匹配技能名称)
  • lsp — 运行 LSP 查询(当前不支持细粒度配置)
  • webfetch — 获取 URL(匹配 URL)
  • websearchcodesearch — 网页/代码搜索(匹配查询内容)
  • external_directory — 当工具访问项目工作目录之外的路径时触发
  • doom_loop — 当同一工具调用以相同输入重复 3 次时触发

默认值

如果你未指定任何配置,MiMo Code 将使用宽松的默认值:

  • 大多数权限默认为 "allow"
  • doom_loopexternal_directory 默认为 "ask"
  • read"allow",但 .env 文件默认被拒绝:
1{
2  "permission": {
3    "read": {
4      "*": "allow",
5      "*.env": "deny",
6      "*.env.*": "deny",
7      "*.env.example": "allow"
8    }
9  }
10}

"Ask"的作用

当 MiMo Code 提示审批时,界面提供三种选择:

  • once — 仅批准本次请求
  • always — 批准与建议模式匹配的后续请求(在当前 MiMo Code 会话的剩余时间内有效)
  • reject — 拒绝请求

always 所批准的模式集合由工具提供(例如,bash 审批通常会将安全的命令前缀如 git status* 加入白名单)。

代理

你可以为每个代理单独覆盖权限。代理权限会与全局配置合并,且代理规则优先。了解更多关于代理权限的内容。

NOTE: 有关更详细的模式匹配示例,请参阅上方的细粒度规则(对象语法)部分。

1{
2  "$schema": "https://mimo.xiaomi.com//config.json",
3  "permission": {
4    "bash": {
5      "*": "ask",
6      "git *": "allow",
7      "git commit *": "deny",
8      "git push *": "deny",
9      "grep *": "allow"
10    }
11  },
12  "agent": {
13    "build": {
14      "permission": {
15        "bash": {
16          "*": "ask",
17          "git *": "allow",
18          "git commit *": "ask",
19          "git push *": "deny",
20          "grep *": "allow"
21        }
22      }
23    }
24  }
25}

你还可以在 Markdown 中配置代理权限:

1description: Code review without edits
2mode: subagent
3permission:
4  edit: deny
5  bash: ask
6  webfetch: deny
7
8Only analyze code and suggest changes.

TIP: 对带参数的命令使用模式匹配。"grep *" 允许执行 grep pattern file.txt,而单独的 "grep" 则会阻止它。像 git status 这样的命令适用于默认行为,但在传递参数时需要显式权限(如 "git status *")。