Archive existing wiki knowledge and rebuild from scratch, or restore from a previous archive. Use this skill when the user wants to start fresh, rebuild the wiki from all sources, archive current knowledge before a major change, or restore an older version. Triggers on "rebuild the wiki", "start over", "archive and rebuild", "restore from archive", "nuke and repave", "clean rebuild". Also use when the wiki has drifted too far from sources and incremental fixes won't cut it.
You are performing a destructive operation on the wiki. Always archive first, always confirm with the user before proceeding.
.env to get OBSIDIAN_VAULT_PATH.manifest.json to understand current stateArchives live at $OBSIDIAN_VAULT_PATH/_archives/. Each archive is a timestamped directory containing a full copy of the wiki state at that point.
$OBSIDIAN_VAULT_PATH/
├── _archives/
│ ├── 2026-04-01T10-30-00Z/
│ │ ├── archive-meta.json
│ │ ├── concepts/
│ │ ├── entities/
│ │ ├── skills/
│ │ ├── references/
│ │ ├── synthesis/
│ │ ├── journal/
│ │ ├── projects/
│ │ ├── index.md
│ │ ├── log.md
│ │ └── .manifest.json
│ └── 2026-03-15T08-00-00Z/
│ └── ...
├── concepts/ ← live wiki
├── entities/
└── ...
{
"archived_at": "2026-04-06T10:30:00Z",
"reason": "rebuild",
"total_pages": 87,
"total_sources": 42,
"total_projects": 6,
"vault_path": "/Users/name/Knowledge",
"manifest_snapshot": ".manifest.json"
}
When the user wants to snapshot the current state without rebuilding.
_archives/YYYY-MM-DDTHH-MM-SSZ/index.md, log.md, .manifest.json, and projects/ into the archivearchive-meta.json with reason "snapshot"log.md:
- [TIMESTAMP] ARCHIVE reason="snapshot" pages=87 destination="_archives/2026-04-06T10-30-00Z"
When the user wants to start fresh. This is the full sequence:
Same as Mode 1 above, but with reason "rebuild".
Remove all content from the category directories (concepts/, entities/, skills/, etc.) and the projects/ directory. Keep:
_archives/ (obviously).obsidian/ (Obsidian config).env (if present in vault)Reset index.md to the empty template. Reset log.md with just the rebuild entry. Delete .manifest.json (it'll be recreated during ingest).
Tell the user the vault is cleared and ready for a full re-ingest. They can now run:
wiki-status — to see all sources as "new"claude-history-ingest — to reprocess Claude historycodex-history-ingest — to reprocess Codex session historywiki-ingest — to reprocess documentsdata-ingest — to reprocess any other dataEach of these will rebuild the manifest as they go.
Important: Don't run the ingest yourself automatically. The user should choose what to re-ingest and in what order. Some sources may no longer be relevant.
Append to log.md:
- [TIMESTAMP] REBUILD archived_to="_archives/2026-04-06T10-30-00Z" previous_pages=87
When the user wants to go back to a previous state.
Read _archives/ directory. For each archive, read archive-meta.json and present:
## Available Archives
| Date | Reason | Pages | Sources |
|---|---|---|---|
| 2026-04-06 10:30 | rebuild | 87 | 42 |
| 2026-03-15 08:00 | snapshot | 65 | 31 |
Ask the user which archive they want. Warn them that restoring will overwrite the current live wiki.
Before restoring, archive the current state (reason: "pre-restore") so nothing is lost.
index.md, log.md, and .manifest.json from the archivelog.md:
- [TIMESTAMP] RESTORE from="_archives/2026-03-15T08-00-00Z" pages_restored=65
Tell the user what was restored and suggest running wiki-lint to check for any issues with the restored state.
.obsidian/ directory is sacred. Never touch it during archive/rebuild/restore — it contains the user's Obsidian settings, plugins, and themes.