Aiwg kb-health
Lint and health-check the knowledge base. Finds orphan pages, missing cross-references, stale claims, broken wiki-links, and regenerates the index.
git clone https://github.com/jmagly/aiwg
T=$(mktemp -d) && git clone --depth=1 https://github.com/jmagly/aiwg "$T" && mkdir -p ~/.claude/skills && cp -r "$T/.agents/skills/kb-health" ~/.claude/skills/jmagly-aiwg-kb-health && rm -rf "$T"
.agents/skills/kb-health/SKILL.mdKB Health
Audit the knowledge base for structural and content issues. Reports problems and, with
--fix, repairs what can be fixed automatically (broken links, missing index entries). Human review is required for content issues (stale claims, empty sections).
Triggers
- "check KB health" → full audit
- "find orphan pages" → orphan check only
- "regenerate KB index" →
--index-only
→ direct invocation/kb-health
Parameters
--path <subtree>
(optional)
--path <subtree>Scope the check to a subdirectory (e.g.,
--path .aiwg/kb/entities/). Defaults to full KB root.
--kb <path>
(optional)
--kb <path>Root of the knowledge base. Defaults to
.aiwg/kb/.
--fix
(optional)
--fixAutomatically repair issues that are safe to fix without human judgment:
- Remove references to confirmed-missing pages from Sources tables
- Add pages missing from the index
- Normalize slug inconsistencies (spaces → hyphens in filenames)
Does NOT auto-fix: empty required sections, stale claim dates, ambiguous duplicates.
--index-only
(optional)
--index-onlySkip all checks; only regenerate
index.md.
Checks
1. Orphan Pages
An orphan is a page with no incoming
[[wiki-link]] references from any other KB page.
Procedure:
- Collect all
files under.md
.<kb>/ - For each file, extract all
references.[[...]] - Build an inverted index: page → set of pages that link to it.
- Pages with zero incoming links are orphans.
Orphans in
sources/ are less critical (sources are often terminal nodes). Report them separately.
2. Broken Wiki-Links
For every
[[link-target]] found in any KB page:
- Derive the expected file path (slug → filename in each subdirectory).
- Check whether the file exists.
- If not: report as a broken link with the containing file and line number.
With
--fix: remove confirmed-broken links from Sources tables. Flag broken links in prose sections for manual review (do not silently remove).
3. Empty Required Sections
Templates define required sections (Overview, Definition, Key Takeaways, etc.). Detect pages where a required section header exists but the body is a placeholder (
_..._ or a single empty line).
Report as warnings, not errors. Do not auto-fix content.
4. Stale Pages
A page is considered stale if:
- Its
date is more than 180 days ago, AND_Last updated: - At least one source it references was published after that date (detectable via source summary dates)
Report stale pages as advisory — staleness is informational, not a structural error.
5. Duplicate Slugs
Detect files with the same normalized slug in different subdirectories (e.g.,
entities/python.md and concepts/python.md). These may be legitimate or accidental duplicates. Report all cases; do not auto-resolve.
Index Regeneration
Always regenerate
<kb>/index.md at the end of a health check run (or when --index-only is used).
The index lists all KB pages grouped by directory with their first-line description (the
> blockquote line from templates):
# Knowledge Base Index _Generated: YYYY-MM-DD — N pages_ ## Entities (N) - [Entity Name](entities/entity-name.md) — type · domain ## Concepts (N) - [Concept Name](concepts/concept-name.md) — category · domain ## Sources (N) - [Source Title](sources/source-slug.md) — type · author · date ## Comparisons (N) - [A vs B](comparisons/a-vs-b.md) — purpose ## Syntheses (N) - [Synthesis Title](syntheses/synthesis-slug.md) — type · confidence
Report Format
KB Health Report — YYYY-MM-DD Root: .aiwg/kb/ Pages scanned: N ERRORS (must fix) Broken links: N entities/foo.md:12 — [[missing-page]] not found WARNINGS (review recommended) Orphan pages: N sources/old-article.md — no incoming links Empty sections: N concepts/bar.md — Definition section is placeholder Stale pages: N entities/baz.md — last updated 2024-01-01 (>180 days) INFO Duplicate slugs: N entities/python.md and concepts/python.md share slug "python" Index regenerated: .aiwg/kb/index.md (N entries)
Scope Limits
- Read-only by default.
enables targeted writes;--fix
writes only--index-only
.index.md - Do not delete any pages, even if they appear to be duplicates. Report and let the human decide.
- Maximum pages scanned per run: 500. If KB exceeds this, use
to scope.--path
References
- @$AIWG_ROOT/agentic/code/frameworks/knowledge-base/templates/entity-page.md
- @$AIWG_ROOT/agentic/code/frameworks/knowledge-base/templates/concept-page.md
- @$AIWG_ROOT/agentic/code/frameworks/knowledge-base/templates/source-summary.md
- @$AIWG_ROOT/agentic/code/frameworks/knowledge-base/skills/kb-ingest/SKILL.md