[分享创造] noni — 让 AI agent 也能跑 `gh auth login` / `ssh-copy-id` 这类交互式 CLI

4 月 30 日
 2code

做了个小工具叫 noni,开源在 GitHub: https://github.com/williamwa/noni

解决什么问题

gh auth loginssh-copy-idnpm publishnpm login 这些命令默认是交互式的,默认有一个 Terminal, 是人坐在终端前面:选 GitHub.com 还是 Enterprise 、按 y/n 、粘贴 token 、输入密码……

放到 AI agent 场景就很尴尬:agent 在 sandbox 里跑 bash/exec,碰到这种交互,agent 直接卡住。常见的 workaround:

noni 的思路是把这件事变成一系列无状态 RPC 调用

agent: noni run "gh auth login"
noni:  {id: abc, status: waiting_input, prompt: {type: select, options: [...]}}
agent: noni key abc enter
noni:  {id: abc, status: waiting_input, prompt: {type: yesno, default: "y"}}
agent: noni input abc Y
noni:  {id: abc, status: waiting_input, prompt: {type: password, echo: false}}
agent: noni secret abc --env GH_TOKEN
noni:  {id: abc, status: exited, exit_code: 0}

agent 看到的是结构化的 prompt,也可以用 read --raw 来读这屏幕,然后自己决定下一步发什么。这样整个工具调用流程不会卡住。

几个设计细节

  1. prompt 类型靠几个不同信号判断:

    • password:termios ECHO 关掉了(最硬的信号,置信度 0.99 )
    • yesno:识别 (y/n) [Y/n] 等模式,从大写字母抽 default
    • select:找 > * 标记 + 缩进选项块
    • input:行尾 : ? >
    • unknown:1s idle 还匹配不上就 fallback ,让 agent 看 screen 自己判断
  2. noni secret --env VAR —— token 不走 RPC wire 。读的是 daemon 进程的环境变量,所以不会出现在 agent 的 prompt / 日志 / context 里。这是协议层的硬保障,不是约定。

  3. 架构是 stateless CLI + 常驻 daemon:

    noni (CLI) ──JSON-RPC over Unix socket──▶ nonid (daemon) ──PTY──▶ child
    

    socket 在 $XDG_RUNTIME_DIR/noni/sock,0600 。daemon 由 CLI 首次调用时自动 spawn 。

  4. 终端模拟用 hinshun/vt10x,detector 看的是"稳定后的虚拟屏幕"而不是原始字节流,避免被光标移动 / 重绘干扰。

实测

让 agent 在容器里跑 gh auth login 整个 device flow 是能走通的(用户授权那一步还是要人)。完整一次跑下来 14 个 RPC 调用,包括 3 次 select( host / protocol / method )、1 次 yesno(是否用 git credentials )、最后 enter 等待 device 授权完成。

安装

brew install williamwa/tap/noni
# 或
go install github.com/williamwa/noni/cmd/noni@latest
go install github.com/williamwa/noni/cmd/nonid@latest

Linux 主测,macOS 能跑。

Go 单文件,无运行时依赖。还在 v0.1.0-dev ,欢迎拍砖 / issue / PR:

👉 https://github.com/williamwa/noni

720 次点击
所在节点    分享创造
0 条回复

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1209738

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX