skills/pkm-documentation/SKILL.md
Personal Knowledge Management documentation system based on Zettelkasten principles. Use when documenting conversations, decisions, development work, learnings, or any knowledge that should persist. Triggers on new projects, technical decisions, completed tasks, lessons learned, meeting notes, or when the user says "document this". Apply this workflow to all daily memory notes and long-term memory updates.
npx skillsauth add balin-ar/pkm-documentation pkm-documentationInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
If the knowledge/ directory doesn't exist in your workspace, run the setup script:
bash skills/pkm-documentation/scripts/setup.sh
This creates the vault structure and patches AGENTS.md, SOUL.md, and MEMORY.md with PKM instructions. Alternatively, create the directories manually: knowledge/{decisions,devlog,learnings,projects,conversations,daily}.
Document everything worth keeping using atomic, connected, iterative notes. Based on Zettelkasten method adapted for an AI agent workspace.
Read this file BEFORE writing any note. No exceptions.
knowledge/ vault[[wiki-links]] Obsidian-style for cross-references.[SUPERSEDED] rather than removing.knowledge/
├── decisions/ → Decision Records (🔀)
├── devlog/ → Development Logs (🔧)
├── learnings/ → Learning Notes (💡)
├── projects/ → Project Notes (📦) — no date, updated in-place
├── conversations/ → Conversation Summaries (💬)
├── daily/ → Daily indices (links to the day's notes)
└── README.md → Vault map
YYYY-MM-DD-descriptive-slug.md (decisions, devlog, learnings, conversations)project-name.md (projects — updated in-place)YYYY-MM-DD.md (only links to the day's notes)Use when a technical or strategic decision is made.
## 🔀 Decision: [title]
- **Date:** YYYY-MM-DD
- **Context:** Why this came up
- **Options considered:** What alternatives existed
- **Decision:** What we chose
- **Reasoning:** Why
- **Consequences:** What this affects
- **Related:** [[type/file]] | [[type/file]]
Use when building, fixing, or shipping something.
## 🔧 Dev: [what was built/fixed]
- **Date:** YYYY-MM-DD
- **Project:** [[projects/name]]
- **What changed:** Brief description
- **Technical details:** Implementation notes worth remembering
- **Issues hit:** Problems encountered and how they were solved
- **Related:** [[type/file]] | [[type/file]]
Use when discovering something new — a tool, technique, pattern.
## 💡 Learning: [topic]
- **Date:** YYYY-MM-DD
- **Source:** Where this came from (tweet, docs, experiment)
- **Key insight:** The core takeaway in 1-2 sentences
- **Details:** Deeper explanation if needed
- **Application:** How this applies to our work
- **Related:** [[type/file]] | [[type/file]]
Use when starting or significantly updating a project.
## 📦 Project: [name]
- **Status:** active | paused | completed | abandoned
- **Goal:** What this project achieves
- **Stack:** Technologies used
- **Architecture:** Key design decisions
- **Current state:** Where things stand
- **Next steps:** What comes next
- **Related:** [[type/file]] | [[type/file]]
Use at end of significant conversations with the user.
## 💬 Conversation: [topic]
- **Date:** YYYY-MM-DD
- **Topics covered:** Bullet list
- **Decisions made:** What was decided (link to decision records)
- **Action items:** What needs to happen next
- **Open questions:** Unresolved items
Lightweight daily index. Links only.
# YYYY-MM-DD
## Notes of the day
- [[devlog/YYYY-MM-DD-slug]] — short description
- [[decisions/YYYY-MM-DD-slug]] — short description
- [[learnings/YYYY-MM-DD-slug]] — short description
- [[conversations/YYYY-MM-DD-slug]] — short description
Use [[folder/filename]] to connect notes:
- **Related:** [[projects/webclaw-fork]] | [[devlog/2026-02-10-browserless-setup]]
Common patterns:
To avoid filling the main context or slowing down:
task with all necessary contextsessions_spawnDocument in knowledge vault (knowledge/):
- Type: devlog
- File: knowledge/devlog/2026-02-10-feature-x.md
- Content: [detailed description of what was done, issues, etc.]
- Related: [[projects/name]] | [[decisions/date-slug]]
Also update knowledge/daily/2026-02-10.md adding the link.
MEMORY.md with link to the vaultMEMORY.md (with links to the vault)knowledge/projects/MEMORY.md remains the executive summary loaded every session. But now:
→ see [[devlog/2026-02-10-slug]]When the user asks to learn about a topic:
knowledge/learnings/YYYY-MM-DD-<topic>.md✅ Always document:
❌ Skip:
development
Maintainer-only workflow for handling GitHub Secret Scanning alerts on OpenClaw. Use when Codex needs to triage, redact, clean up, and resolve secret leakage found in issue comments, issue bodies, PR comments, or other GitHub content.
development
Maintainer workflow for OpenClaw releases, prereleases, changelog release notes, and publish validation. Use when Codex needs to prepare or verify stable or beta release steps, align version naming, assemble release notes, check release auth requirements, or validate publish-time commands and artifacts.
development
Run, watch, debug, and extend OpenClaw QA testing with qa-lab and qa-channel. Use when Codex needs to execute the repo-backed QA suite, inspect live QA artifacts, debug failing scenarios, add new QA scenarios, or explain the OpenClaw QA workflow. Prefer the live OpenAI lane with regular openai/gpt-5.4 in fast mode; do not use gpt-5.4-pro or gpt-5.4-mini unless the user explicitly overrides that policy.
development
End-to-end Parallels smoke, upgrade, and rerun workflow for OpenClaw across macOS, Windows, and Linux guests. Use when Codex needs to run, rerun, debug, or interpret VM-based install, onboarding, gateway smoke tests, latest-release-to-main upgrade checks, fresh snapshot retests, or optional Discord roundtrip verification under Parallels.