An AI Project Manager for OpenClaw and Hermes Agent.
Languages: English · 简体中文 · 繁體中文
Heads up — early development. This project is still in its initial development phase. The design, repo layout, and APIs are not yet stable, and most skills below are planned rather than shipped. Star / watch the repo and stay tuned — a first MVP (M1) is on the way. Feedback and issues are very welcome.
pmgo is a runtime-neutral Agent persona + MCP Skills Pack that turns your OpenClaw or Hermes gateway into a digital project manager. It covers four scenarios with one codebase:
- Personal GTD / OKR
- Agile team workflows (Jira, Linear, GitHub Issues)
- Full software development lifecycle (requirements → dev → test → release)
- General team project management (Feishu, DingTalk, Notion)
It ships as a skills pack, not a fork — one MCP server and one memory store work on both runtimes without merge pain.
- Dual runtime — same skills on OpenClaw and Hermes; see runtimes/README.md.
- Multi-channel — Telegram, Feishu, Slack, Discord, WhatsApp, and more via your gateway.
- Always-on — heartbeats drive morning briefings, blocker scans, and Friday reports without you asking.
- Persistent memory — SQLite + human-readable Markdown under
memory/projects/<slug>/. - Sandboxed — allow-list policy for sensitive writes (Jira transitions, PR close, file writes).
- Multi-agent — a main
pmgobrain delegates toplanner,tracker,risker, andreportersub-agents. - i18n-ready — English, Simplified Chinese, and Traditional Chinese out of the box.
Early development — commands below are the target UX. See runtimes/ for gateway-specific steps.
# 1) Bootstrap local memory + linked project (runtime-agnostic)
npm run gtd:bootstrap -- --name "My GTD" --locale zh-CN
export PMGO_DEFAULT_PROJECT_ID="<uuid-from-output>"
export PMGO_WORKSPACE="/absolute/path/to/pmgo"
# 2) Pick a runtime and register MCP (prints ready-to-run snippet)
npm run runtime:config -- --runtime openclaw # or: hermes
# 3) OpenClaw: openclaw agent add ./agent
# Hermes: hermes claw migrate OR copy agent/SOUL.md → ~/.hermes/SOUL.mdGuides: OpenClaw · Hermes · GTD quickstart (OpenClaw)
agent/— persona package (SOUL.md,IDENTITY.md,USER.md,TOOLS.md,AGENTS.md)runtimes/— OpenClaw and Hermes integration guidesshared/— shared MCP env and cron message templatesskills/- MCP skill definitions and implementationslocales/- runtime i18n dictionaries (en,zh-CN,zh-TW)policy/pmgo.policy.yaml- allow-list and confirmation policycron/jobs.yaml- proactive heartbeat and scheduled jobsmemory/templates/- locale-aware reporting templatesmemory/schema.sql- canonical SQLite schema snapshotmemory/migrations/- append-only schema migration history
pmgo uses a hybrid memory model:
- SQLite DB (
memory/pmgo.db) stores structured long-term entities. - Schema SQL (
memory/schema.sql) defines canonical database structure. - Markdown (
memory/projects/<slug>/) stores human-readable project notes.
Initialize and verify local memory DB:
npm run memory:check
npm run memory:init
npm run memory:migrate
npm run memory:verifyOr run the full bootstrap pipeline in one command:
npm run memory:scaffoldAnd with project markdown scaffolding:
npm run memory:scaffold -- --project-name "PMGO MVP" --locale zh-CNInitialize project-scoped markdown memory directory:
npm run memory:init:project -- --name "PMGO MVP" --locale enOptional arguments:
--slugto force a custom directory name undermemory/projects/.--localesupportsen,zh-CN, andzh-TW(default:en).
Set GITHUB_TOKEN and GITHUB_REPO=owner/name (for example flygoly/pmgo). Then use the bundled REST helper:
npm run github-issues -- smoke
npm run github-issues -- list --state open
npm run github-issues -- import-task --project-id <UUID> --number 42Details: skills/integration-github/SKILL.md. Importing creates a local task with source=github and external_id set to GitHub’s numeric issue id for idempotency.
Set LINEAR_API_KEY from Linear → Settings → API. Then:
npm run linear-issues -- smoke
npm run linear-issues -- list --first 10
npm run linear-issues -- get ENG-123
npm run linear-issues -- import-task --project-id <UUID> --identifier ENG-123Details: skills/integration-linear/SKILL.md. Importing sets source=linear and external_id to Linear’s issue UUID.
Set JIRA_BASE_URL, JIRA_EMAIL, and JIRA_API_TOKEN (optional JIRA_PROJECT for default list JQL). Then:
npm run jira-issues -- smoke
npm run jira-issues -- list --max-results 10
npm run jira-issues -- get PROJ-123
npm run jira-issues -- import-task --project-id <UUID> --issue-key PROJ-123Details: skills/integration-jira/SKILL.md. Importing sets source=jira and external_id to Jira’s numeric issue id.
Register the policy-aware MCP server (scripts/pmgo_mcp_server.py), connect channels, and schedule daily/weekly runs:
| Runtime | Guide |
|---|---|
| OpenClaw | runtimes/openclaw/README.md |
| Hermes | runtimes/hermes/README.md |
| Overview | runtimes/README.md |
The repo cron/jobs.yaml is a narrative reference only; use openclaw cron add or hermes cron create in production.
Gateway (OpenClaw or Hermes — channels)
│
▼
pmgo Agent ──► planner / tracker / risker / reporter
│
▼
Skills Pack (MCP stdio — shared)
project-core · daily-standup · weekly-report · risk-radar
integration-{github,linear,jira,notion,feishu,dingtalk}
│
▼
Memory: SQLite + Markdown ◄── Cron / heartbeat
| Milestone | Scope |
|---|---|
| M1 — MVP (2–3 weeks) | Repo scaffold · agent persona · 3 native skills (project-core, daily-standup, weekly-report) · GitHub Issues connector · 1 IM channel (Telegram or Feishu) · end-to-end personal GTD flow |
| M2 — Beta (+3–4 weeks) | risk-radar (Python MCP) · Jira/Linear connector · multi-agent orchestration · cron/heartbeat jobs live |
| M3 — v1.0 (+4–6 weeks) | Feishu/DingTalk/Notion connectors · Gantt & burndown on OpenClaw Live Canvas · publishable SKILL.md for one-click install |
- Code, identifiers, commit messages, and inline comments: English only.
- README: English is canonical;
README.zh-CN.mdandREADME.zh-TW.mdmirror it. - User-facing strings (agent replies, report templates, error messages, UI labels) are loaded from
locales/{en,zh-CN,zh-TW}.jsonand selected per-session based on the user's locale (fallback:en). - Agent persona files:
agent/*.mdare English canonical; localised overlays live underagent/locales/{zh-CN,zh-TW}/*.md. - Contributions: please write new strings in English first, then add translations for
zh-CNandzh-TWin the same PR.
Contributions are welcome. A few ground rules:
- Code, variable names, function names, file names, and commit messages are in English.
- New user-facing strings must be added to all three locale files in the same PR.
- Follow the allow-list policy in
policy/pmgo.policy.yaml— never expand shell or delete permissions casually.
Before opening a PR, run the repository checks (agent i18n validation, memory asset and database verification, project-core list smoke, daily-standup / weekly-report / risk-radar smokes when a project exists, github-issues:smoke, linear-issues:smoke, and jira-issues:smoke when the respective API env vars are missing, and mcp:pmgo:check for OpenClaw MCP dependencies when pip install mcp pyyaml is available):
npm run validateSee CONTRIBUTING.md for the full workflow.
Licensed under the Apache License, Version 2.0. See NOTICE for attribution requirements.