loki-mode
Compare original and translation side by side
🇺🇸
Original
English🇨🇳
Translation
ChineseLoki Mode - OpenClaw Skill
Loki Mode - OpenClaw Skill
When to use
适用场景
- User asks to "build", "implement", or "develop" a feature from a PRD
- User provides a requirements document and wants autonomous execution
- User says "loki mode" or references autonomous development
- User wants to run a full SDLC cycle on a codebase
- 当用户要求「构建」「实现」或「开发」PRD中的某个功能时
- 用户提供需求文档并希望自主执行时
- 用户提及「loki mode」或自主开发时
- 用户希望在代码库上运行完整SDLC周期时
Prerequisites
前置条件
- CLI installed on the host (via
lokior Homebrew)npm install -g loki-mode - One of: Claude Code, Codex CLI, or Gemini CLI installed
- Corresponding API key set (ANTHROPIC_API_KEY, OPENAI_API_KEY, or GOOGLE_API_KEY)
- 主机上已安装CLI(通过
loki或Homebrew安装)npm install -g loki-mode - 已安装以下工具之一:Claude Code、Codex CLI或Gemini CLI
- 已设置对应的API密钥(ANTHROPIC_API_KEY、OPENAI_API_KEY或GOOGLE_API_KEY)
How to invoke
调用方式
Start a session
启动会话
Use the bash tool with background mode:
bash(command: "loki start <prd-path> --bg --yes --no-dashboard", pty: true, background: true, workdir: "<project-dir>")Key flags:
- : Background mode (session outlives the tool call)
--bg - : Skip confirmation prompts
--yes - : Avoid port conflicts in sandboxed environments
--no-dashboard - : Select AI provider (default: claude)
--provider <claude|codex|gemini> - : Set cost limit in USD (auto-pause when exceeded)
--budget <amount>
使用bash工具的后台模式:
bash(command: "loki start <prd-path> --bg --yes --no-dashboard", pty: true, background: true, workdir: "<project-dir>")关键参数:
- :后台模式(会话独立于工具调用持续运行)
--bg - :跳过确认提示
--yes - :避免在沙箱环境中出现端口冲突
--no-dashboard - :选择AI提供商(默认:claude)
--provider <claude|codex|gemini> - :设置美元计价的成本上限(超出后自动暂停)
--budget <amount>
Monitor progress
监控进度
Poll status every 30 seconds:
bash(command: "loki status --json", workdir: "<project-dir>")The JSON output contains:
- : Loki Mode version string
version - : inactive, running, paused, stopped, completed, unknown
status - : Current SDLC phase (e.g., BOOTSTRAP, DISCOVERY, ARCHITECTURE, DEVELOPMENT, QA, DEPLOYMENT)
phase - : Current iteration number
iteration - : Which AI provider is active (claude, codex, gemini)
provider - : Process ID of the running session (null if not running)
pid - : Seconds since session start
elapsed_time - : URL of the web dashboard (null if disabled)
dashboard_url - : Object with
task_counts,total,completed,failedcountspending
For budget tracking (not in JSON output), read the budget file directly:
bash(command: "cat .loki/metrics/budget.json 2>/dev/null || echo '{}'", workdir: "<project-dir>")Budget JSON fields: ,
budget_limitbudget_used每30秒轮询一次状态:
bash(command: "loki status --json", workdir: "<project-dir>")JSON输出包含以下字段:
- :Loki Mode版本字符串
version - :状态(inactive、running、paused、stopped、completed、unknown)
status - :当前SDLC阶段(例如BOOTSTRAP、DISCOVERY、ARCHITECTURE、DEVELOPMENT、QA、DEPLOYMENT)
phase - :当前迭代次数
iteration - :当前使用的AI提供商(claude、codex、gemini)
provider - :运行会话的进程ID(未运行时为null)
pid - :会话启动后的耗时(秒)
elapsed_time - :Web仪表盘的URL(禁用时为null)
dashboard_url - :任务统计对象,包含
task_counts、total、completed、failed计数pending
对于预算跟踪(不在JSON输出中),直接读取预算文件:
bash(command: "cat .loki/metrics/budget.json 2>/dev/null || echo '{}'", workdir: "<project-dir>")预算JSON字段:、
budget_limitbudget_usedReport progress to channel
向渠道汇报进度
After each poll, summarize changes:
- Phase transitions ("Moved from ARCHITECTURE to DEVELOPMENT")
- Task completion counts ("12/20 tasks complete, 0 failed")
- Elapsed time ("Running for 45 minutes")
- Error states that need attention (failed tasks > 0, status is unknown)
If budget tracking is active, include cost in updates:
- "Estimated cost: $4.50 / $50.00 budget"
每次轮询后,总结变更内容:
- 阶段转换(例如「从ARCHITECTURE阶段进入DEVELOPMENT阶段」)
- 任务完成计数(例如「20项任务已完成12项,0项失败」)
- 耗时(例如「已运行45分钟」)
- 需要关注的错误状态(失败任务数>0、状态为unknown)
如果启用了预算跟踪,更新内容中需包含成本信息:
- 「预估成本:$4.50 / 预算上限$50.00」
Control commands
控制命令
- Pause:
bash(command: "loki pause", workdir: "<project-dir>") - Resume:
bash(command: "loki resume", workdir: "<project-dir>") - Stop:
bash(command: "loki stop", workdir: "<project-dir>") - Status:
bash(command: "loki status", workdir: "<project-dir>") - Logs:
bash(command: "loki logs --tail 50", workdir: "<project-dir>")
- 暂停:
bash(command: "loki pause", workdir: "<project-dir>") - 恢复:
bash(command: "loki resume", workdir: "<project-dir>") - 停止:
bash(command: "loki stop", workdir: "<project-dir>") - 状态:
bash(command: "loki status", workdir: "<project-dir>") - 日志:
bash(command: "loki logs --tail 50", workdir: "<project-dir>")
Session complete
会话完成
When status becomes "stopped" or "completed":
- Run for final summary
loki status --json - Run to show commits made
git log --oneline -20 - Report final task counts, elapsed time, and duration
- If council verdict exists, include it:
cat .loki/council/report.md
当状态变为「stopped」或「completed」时:
- 运行获取最终总结
loki status --json - 运行查看提交记录
git log --oneline -20 - 汇报最终任务计数、耗时和总时长
- 如果存在评审结论,包含该内容:
cat .loki/council/report.md
Critical rules
重要规则
- ALWAYS use --bg flag (session must outlive the tool call)
- ALWAYS use --yes flag (no confirmation prompts in non-interactive channels)
- NEVER run loki in the OpenClaw workspace directory itself
- Poll status rather than watching stdout (background mode detaches)
- If session crashes, check before restarting
loki logs - Respect budget limits -- include cost in every progress update when tracking is active
- The --no-dashboard flag is recommended to avoid port conflicts in sandboxed environments
- 务必使用--bg参数(会话必须独立于工具调用持续运行)
- 务必使用--yes参数(在非交互式渠道中跳过确认提示)
- 绝对不要在OpenClaw工作区目录本身中运行loki
- 通过轮询状态而非监控stdout来跟踪进度(后台模式会分离进程)
- 如果会话崩溃,先检查再重启
loki logs - 遵守预算限制——启用跟踪时,每次进度更新都要包含成本信息
- 建议使用--no-dashboard参数,避免在沙箱环境中出现端口冲突