@jayjiang/byoao 1.1.2 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/__tests__/plugin-config.test.js +7 -10
- package/dist/__tests__/plugin-config.test.js.map +1 -1
- package/dist/assets/obsidian-skills/byoao-conventions.md +30 -54
- package/dist/assets/obsidian-skills/vault-thinking.md +6 -5
- package/dist/assets/presets/common/AGENTS.md.hbs +29 -46
- package/dist/assets/presets/common/SCHEMA.md.hbs +57 -0
- package/dist/assets/presets/common/Start Here.md.hbs +29 -40
- package/dist/assets/presets/minimal/preset.json +3 -3
- package/dist/assets/presets/pm-tpm/preset.json +2 -2
- package/dist/assets/skills/ask.md +28 -27
- package/dist/assets/skills/challenge.md +79 -121
- package/dist/assets/skills/connect.md +75 -163
- package/dist/assets/skills/cook.md +167 -0
- package/dist/assets/skills/diagnose.md +102 -43
- package/dist/assets/skills/drift.md +64 -165
- package/dist/assets/skills/health.md +63 -0
- package/dist/assets/skills/ideas.md +11 -10
- package/dist/assets/skills/organize.md +56 -155
- package/dist/assets/skills/prep.md +63 -0
- package/dist/assets/skills/trace.md +75 -90
- package/dist/assets/skills/wiki.md +77 -178
- package/dist/cli/cli-program.js +17 -14
- package/dist/cli/cli-program.js.map +1 -1
- package/dist/cli/installer.js +10 -4
- package/dist/cli/installer.js.map +1 -1
- package/dist/hooks/idle-suggestions.js +4 -4
- package/dist/hooks/idle-suggestions.js.map +1 -1
- package/dist/hooks/system-transform.js +35 -1
- package/dist/hooks/system-transform.js.map +1 -1
- package/dist/index.js +395 -623
- package/dist/index.js.map +1 -1
- package/dist/plugin-config.js +6 -32
- package/dist/plugin-config.js.map +1 -1
- package/dist/tools/init-vault.js +8 -38
- package/dist/tools/init-vault.js.map +1 -1
- package/dist/tools/vault-doctor.js +1 -1
- package/dist/tools/vault-doctor.js.map +1 -1
- package/dist/tools/vault-status.js +1 -1
- package/dist/tools/vault-status.js.map +1 -1
- package/dist/vault/__tests__/create.test.js +47 -115
- package/dist/vault/__tests__/create.test.js.map +1 -1
- package/dist/vault/__tests__/doctor.test.js +14 -2
- package/dist/vault/__tests__/doctor.test.js.map +1 -1
- package/dist/vault/__tests__/manifest.test.js +2 -2
- package/dist/vault/__tests__/manifest.test.js.map +1 -1
- package/dist/vault/__tests__/status.test.js +12 -0
- package/dist/vault/__tests__/status.test.js.map +1 -1
- package/dist/vault/__tests__/upgrade.test.js +3 -3
- package/dist/vault/__tests__/upgrade.test.js.map +1 -1
- package/dist/vault/create.js +75 -188
- package/dist/vault/create.js.map +1 -1
- package/dist/vault/doctor.js +49 -0
- package/dist/vault/doctor.js.map +1 -1
- package/dist/vault/manifest.js +1 -1
- package/dist/vault/preset.js +10 -4
- package/dist/vault/preset.js.map +1 -1
- package/dist/vault/self-update.js +1 -1
- package/dist/vault/status.js +24 -0
- package/dist/vault/status.js.map +1 -1
- package/dist/vault/upgrade.js +120 -16
- package/dist/vault/upgrade.js.map +1 -1
- package/package.json +1 -1
- package/src/assets/obsidian-skills/byoao-conventions.md +9 -6
- package/src/assets/obsidian-skills/vault-thinking.md +6 -5
- package/src/assets/presets/common/AGENTS.md.hbs +23 -19
- package/src/assets/presets/common/SCHEMA.md.hbs +57 -0
- package/src/assets/presets/common/Start Here.md.hbs +29 -40
- package/src/assets/presets/minimal/preset.json +3 -3
- package/src/assets/presets/pm-tpm/preset.json +2 -2
- package/src/skills/ask.md +28 -27
- package/src/skills/challenge.md +79 -121
- package/src/skills/connect.md +75 -163
- package/src/skills/cook.md +167 -0
- package/src/skills/diagnose.md +102 -43
- package/src/skills/drift.md +64 -165
- package/src/skills/health.md +63 -0
- package/src/skills/ideas.md +11 -10
- package/src/skills/organize.md +56 -155
- package/src/skills/prep.md +63 -0
- package/src/skills/trace.md +75 -90
- package/src/skills/wiki.md +77 -178
- package/dist/assets/presets/common/Glossary.md.hbs +0 -16
- package/dist/assets/presets/common/obsidian/daily-notes.json +0 -5
- package/dist/assets/presets/common/obsidian/templates.json +0 -3
- package/dist/assets/presets/common/templates/Daily Note.md +0 -19
- package/dist/assets/presets/common/templates/Decision Record.md +0 -32
- package/dist/assets/presets/common/templates/Investigation.md +0 -34
- package/dist/assets/presets/common/templates/Meeting Notes.md +0 -25
- package/dist/assets/skills/emerge.md +0 -168
- package/dist/assets/skills/weave.md +0 -287
- package/dist/tools/add-glossary-term.js +0 -21
- package/dist/tools/add-glossary-term.js.map +0 -1
- package/dist/tools/add-person.js +0 -21
- package/dist/tools/add-person.js.map +0 -1
- package/dist/tools/add-project.js +0 -24
- package/dist/tools/add-project.js.map +0 -1
- package/dist/tools/graph-health.js +0 -25
- package/dist/tools/graph-health.js.map +0 -1
- package/dist/tools/note-read.js +0 -19
- package/dist/tools/note-read.js.map +0 -1
- package/dist/tools/search-vault.js +0 -22
- package/dist/tools/search-vault.js.map +0 -1
- package/dist/vault/__tests__/glossary.test.js +0 -68
- package/dist/vault/__tests__/glossary.test.js.map +0 -1
- package/dist/vault/__tests__/graph-health.test.js +0 -102
- package/dist/vault/__tests__/graph-health.test.js.map +0 -1
- package/dist/vault/__tests__/member.test.js +0 -85
- package/dist/vault/__tests__/member.test.js.map +0 -1
- package/dist/vault/__tests__/note-read.test.js +0 -71
- package/dist/vault/__tests__/note-read.test.js.map +0 -1
- package/dist/vault/__tests__/obsidian-cli.test.js +0 -108
- package/dist/vault/__tests__/obsidian-cli.test.js.map +0 -1
- package/dist/vault/__tests__/search-vault.test.js +0 -93
- package/dist/vault/__tests__/search-vault.test.js.map +0 -1
- package/dist/vault/glossary.js +0 -27
- package/dist/vault/glossary.js.map +0 -1
- package/dist/vault/graph-health.js +0 -83
- package/dist/vault/graph-health.js.map +0 -1
- package/dist/vault/member.js +0 -67
- package/dist/vault/member.js.map +0 -1
- package/dist/vault/note-read.js +0 -70
- package/dist/vault/note-read.js.map +0 -1
- package/dist/vault/project.js +0 -68
- package/dist/vault/project.js.map +0 -1
- package/dist/vault/retrieval-types.js +0 -5
- package/dist/vault/retrieval-types.js.map +0 -1
- package/dist/vault/search-vault.js +0 -87
- package/dist/vault/search-vault.js.map +0 -1
- package/src/assets/presets/common/obsidian/daily-notes.json +0 -5
- package/src/assets/presets/common/obsidian/templates.json +0 -3
- package/src/assets/presets/common/templates/Daily Note.md +0 -19
- package/src/assets/presets/common/templates/Decision Record.md +0 -32
- package/src/assets/presets/common/templates/Investigation.md +0 -34
- package/src/assets/presets/common/templates/Meeting Notes.md +0 -25
- package/src/skills/emerge.md +0 -168
- package/src/skills/weave.md +0 -287
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
# SCHEMA.md
|
|
2
|
+
|
|
3
|
+
Knowledge taxonomy and conventions for [[{{KB_NAME}}]].
|
|
4
|
+
|
|
5
|
+
## Knowledge Domains
|
|
6
|
+
|
|
7
|
+
{{#if WIKI_DOMAIN}}
|
|
8
|
+
{{WIKI_DOMAIN}}
|
|
9
|
+
{{else}}
|
|
10
|
+
Not yet defined. The Agent will populate this as it learns the domain.
|
|
11
|
+
{{/if}}
|
|
12
|
+
|
|
13
|
+
## Tag Taxonomy
|
|
14
|
+
|
|
15
|
+
Tags follow these conventions:
|
|
16
|
+
- 2-5 tags per page, alphabetically sorted
|
|
17
|
+
- Tags should be singular (use `#project` not `#projects`)
|
|
18
|
+
- New tags should be added here first before use
|
|
19
|
+
|
|
20
|
+
### Current Tags
|
|
21
|
+
|
|
22
|
+
No tags defined yet. The Agent will propose new tags as knowledge pages are created.
|
|
23
|
+
|
|
24
|
+
## Domain Taxonomy
|
|
25
|
+
|
|
26
|
+
No domains defined yet. The Agent will propose domains as knowledge pages are created.
|
|
27
|
+
|
|
28
|
+
## Agent Page Conventions
|
|
29
|
+
|
|
30
|
+
| Directory | Purpose |
|
|
31
|
+
|-----------|---------|
|
|
32
|
+
| `entities/` | Concrete, named things (people, organizations, products, systems) |
|
|
33
|
+
| `concepts/` | Abstract ideas (methods, rules, decisions, processes) |
|
|
34
|
+
| `comparisons/` | Side-by-side analyses of options |
|
|
35
|
+
| `queries/` | User-question-driven answers worth keeping |
|
|
36
|
+
|
|
37
|
+
## Frontmatter Schema
|
|
38
|
+
|
|
39
|
+
See the /cook skill specification for the complete frontmatter schema. Key required fields:
|
|
40
|
+
|
|
41
|
+
- `title` — concise one-line summary
|
|
42
|
+
- `date` — primary temporal anchor (ISO 8601)
|
|
43
|
+
- `created` — page creation date
|
|
44
|
+
- `updated` — last content change date (bump on every edit)
|
|
45
|
+
- `type` — one of: entity, concept, comparison, query
|
|
46
|
+
- `tags` — 2-5 tags from this taxonomy, alphabetically sorted
|
|
47
|
+
- `sources` — relative paths to contributing notes
|
|
48
|
+
|
|
49
|
+
## Page Thresholds
|
|
50
|
+
|
|
51
|
+
- Create a page when: entity/concept appears in 2+ notes OR is central subject of one note
|
|
52
|
+
- Split a page when: it exceeds ~200 lines
|
|
53
|
+
- Do NOT create pages for: passing mentions, minor details, out-of-domain topics
|
|
54
|
+
|
|
55
|
+
## Custom Fields
|
|
56
|
+
|
|
57
|
+
No custom fields defined yet. The Agent documents new fields here when first used.
|
|
@@ -7,8 +7,8 @@ tags: [onboarding]
|
|
|
7
7
|
|
|
8
8
|
# Welcome to {{KB_NAME}}
|
|
9
9
|
|
|
10
|
-
Your
|
|
11
|
-
|
|
10
|
+
Your LLM-powered knowledge base. Write notes freely, and let AI
|
|
11
|
+
compile them into structured, cross-referenced knowledge pages.
|
|
12
12
|
|
|
13
13
|
## Choose Your Path
|
|
14
14
|
|
|
@@ -25,58 +25,43 @@ you decide what belongs in your local knowledge base.
|
|
|
25
25
|
and drop them into this vault folder.
|
|
26
26
|
2. **Obsidian Web Clipper** — Install the browser extension to save
|
|
27
27
|
any web page directly into your vault as a clean markdown note.
|
|
28
|
-
3. **Write summaries** —
|
|
29
|
-
note that captures the key insights and link back to the source:
|
|
28
|
+
3. **Write summaries** — Create a local note that captures key insights.
|
|
30
29
|
|
|
31
|
-
|
|
32
|
-
---
|
|
33
|
-
title: "Migration Plan Q2"
|
|
34
|
-
source: "https://confluence.example.com/pages/12345"
|
|
35
|
-
---
|
|
36
|
-
```
|
|
37
|
-
|
|
38
|
-
> The `source` property keeps the connection between your local note
|
|
39
|
-
> and the cloud original. Add it whenever a note originates from an
|
|
40
|
-
> external document.
|
|
41
|
-
|
|
42
|
-
**Once you have a few notes → run `/weave`** (see below).
|
|
30
|
+
**Once you have a few notes → run `/cook`** (see below).
|
|
43
31
|
|
|
44
32
|
### Path B: I already have local notes
|
|
45
33
|
|
|
46
|
-
If you have existing markdown files
|
|
34
|
+
If you have existing markdown files:
|
|
47
35
|
|
|
48
36
|
1. **Drop them in** — Copy or move your files into this vault folder.
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
wikilinks, or any particular organization yet.
|
|
37
|
+
2. **Don't worry about structure** — Your files don't need frontmatter
|
|
38
|
+
or any particular organization yet.
|
|
52
39
|
|
|
53
|
-
**Run `/
|
|
54
|
-
|
|
55
|
-
and build your [[Glossary]] from frequently mentioned concepts.
|
|
40
|
+
**Run `/cook` now** — it will scan your notes, identify entities and
|
|
41
|
+
concepts, and compile them into structured knowledge pages.
|
|
56
42
|
|
|
57
43
|
### Path C: Starting fresh
|
|
58
44
|
|
|
59
45
|
No existing notes? No problem.
|
|
60
46
|
|
|
61
47
|
1. Press `Cmd+T` (Mac) or `Ctrl+T` (Windows) → choose "Daily Note".
|
|
62
|
-
2. Write what's on your mind today.
|
|
63
|
-
3. After a few notes, run `/
|
|
48
|
+
2. Write what's on your mind today.
|
|
49
|
+
3. After a few notes, run `/cook` to compile them.
|
|
64
50
|
|
|
65
51
|
---
|
|
66
52
|
|
|
67
|
-
## /
|
|
68
|
-
|
|
69
|
-
Open your AI agent and type `/weave`. It will:
|
|
53
|
+
## /cook — Where the Magic Happens
|
|
70
54
|
|
|
71
|
-
|
|
72
|
-
- **Create wikilinks** — connect related notes automatically
|
|
73
|
-
- **Build your Glossary** — extract key terms and concepts
|
|
74
|
-
- **Suggest organization** — propose directory structure (with your approval)
|
|
55
|
+
Open your AI agent and type `/cook`. It will:
|
|
75
56
|
|
|
76
|
-
|
|
57
|
+
- **Read your notes** — from anywhere in the vault
|
|
58
|
+
- **Identify entities** — people, organizations, products, systems
|
|
59
|
+
- **Identify concepts** — methods, rules, decisions, processes
|
|
60
|
+
- **Create/update pages** — in `entities/`, `concepts/`, `comparisons/`, `queries/`
|
|
61
|
+
- **Flag contradictions** — when notes disagree
|
|
62
|
+
- **Report in plain language** — what changed, what needs your attention
|
|
77
63
|
|
|
78
|
-
After
|
|
79
|
-
knowledge visualized. Every node is a note, every line is a connection.
|
|
64
|
+
After cooking, press `Cmd+G` to open Graph View and see the connections.
|
|
80
65
|
|
|
81
66
|
---
|
|
82
67
|
|
|
@@ -97,15 +82,17 @@ knowledge visualized. Every node is a note, every line is a connection.
|
|
|
97
82
|
|
|
98
83
|
| Command | What it does |
|
|
99
84
|
|---------|-------------|
|
|
100
|
-
| `/
|
|
101
|
-
| `/
|
|
85
|
+
| `/cook` | Compile notes into structured knowledge pages |
|
|
86
|
+
| `/health` | Check knowledge page health |
|
|
87
|
+
| `/wiki` | Generate INDEX.base knowledge map |
|
|
88
|
+
| `/organize` | Reorganize vault directories |
|
|
89
|
+
| `/ask` | Open-ended Q&A against your knowledge |
|
|
102
90
|
| `/trace` | Track how an idea evolved over time |
|
|
103
|
-
| `/emerge` | Discover patterns you haven't noticed |
|
|
104
91
|
| `/connect` | Bridge two seemingly unrelated topics |
|
|
105
92
|
| `/ideas` | Generate actionable ideas from your vault |
|
|
106
93
|
| `/challenge` | Pressure-test a belief against your own notes |
|
|
107
94
|
| `/drift` | Compare intentions vs actions over time |
|
|
108
|
-
| `/diagnose` | Check
|
|
95
|
+
| `/diagnose` | Check overall vault health |
|
|
109
96
|
|
|
110
97
|
{{#if HAS_MCP_SERVICES}}
|
|
111
98
|
|
|
@@ -122,11 +109,13 @@ These services authenticate via your browser. If a connection expires,
|
|
|
122
109
|
tell the agent: "reconnect to {service name}".
|
|
123
110
|
|
|
124
111
|
{{/if}}
|
|
112
|
+
|
|
125
113
|
---
|
|
126
114
|
|
|
127
115
|
## Key Files
|
|
128
116
|
|
|
129
|
-
- **[[
|
|
117
|
+
- **[[SCHEMA]]** — Tag taxonomy and knowledge conventions
|
|
118
|
+
- **[[log]]** — Agent activity log
|
|
130
119
|
- **AGENTS.md** — How AI agents navigate this vault
|
|
131
120
|
|
|
132
121
|
---
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "minimal",
|
|
3
|
-
"displayName": "
|
|
4
|
-
"description": "
|
|
3
|
+
"displayName": "Minimal",
|
|
4
|
+
"description": "Core LLM Wiki with no extra MCP servers or role-specific directories",
|
|
5
5
|
"directories": [],
|
|
6
|
-
"agentDescription": "
|
|
6
|
+
"agentDescription": "LLM Wiki knowledge base. Use /cook to digest notes and external sources. Use /health to health-check.",
|
|
7
7
|
"frontmatterExtras": {},
|
|
8
8
|
"templates": [],
|
|
9
9
|
"mcpServers": {},
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "pm-tpm",
|
|
3
3
|
"displayName": "PM / TPM",
|
|
4
|
-
"description": "
|
|
4
|
+
"description": "Adds Atlassian + BigQuery MCP servers, project directories, and PM templates on top of the core LLM Wiki",
|
|
5
5
|
"directories": ["Projects", "Sprints"],
|
|
6
|
-
"agentDescription": "PM/TPM
|
|
6
|
+
"agentDescription": "LLM Wiki knowledge base with PM/TPM tooling. Use /cook to digest notes and external sources. Use /health to health-check. Atlassian and BigQuery are connected.",
|
|
7
7
|
"frontmatterExtras": {
|
|
8
8
|
"project": ["jira", "stakeholders", "priority"],
|
|
9
9
|
"sprint": ["sprint-dates", "jira-board"]
|
package/src/skills/ask.md
CHANGED
|
@@ -1,11 +1,15 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: ask
|
|
3
|
-
description:
|
|
3
|
+
description: >
|
|
4
|
+
Open-ended Q&A against the knowledge base. Agent reads INDEX.base for page discovery and
|
|
5
|
+
SCHEMA.md for tag taxonomy, navigates entities/, concepts/, comparisons/, and queries/,
|
|
6
|
+
synthesizes answers with citations. Use when the user asks questions about vault content like
|
|
7
|
+
"what is X", "why did we decide", "explain Y", or wants to query their accumulated knowledge.
|
|
4
8
|
---
|
|
5
9
|
|
|
6
10
|
# /ask — Knowledge Q&A
|
|
7
11
|
|
|
8
|
-
You are a knowledge assistant. Your job is to answer questions by navigating the vault's knowledge graph, reading relevant
|
|
12
|
+
You are a knowledge assistant. Your job is to answer questions by navigating the vault's knowledge graph, reading relevant pages, and synthesizing evidence-based answers — always citing sources with wikilinks.
|
|
9
13
|
|
|
10
14
|
## Prerequisites Check
|
|
11
15
|
|
|
@@ -15,7 +19,7 @@ You are a knowledge assistant. Your job is to answer questions by navigating the
|
|
|
15
19
|
obsidian --version
|
|
16
20
|
```
|
|
17
21
|
|
|
18
|
-
If this fails, STOP and display the Obsidian CLI availability message (see /
|
|
22
|
+
If this fails, STOP and display the Obsidian CLI availability message (see /prep).
|
|
19
23
|
|
|
20
24
|
## Parameters
|
|
21
25
|
|
|
@@ -28,15 +32,17 @@ If this fails, STOP and display the Obsidian CLI availability message (see /weav
|
|
|
28
32
|
|
|
29
33
|
Identify the key concepts, entities, and intent in the user's question.
|
|
30
34
|
|
|
31
|
-
### Step 2: Locate Relevant
|
|
35
|
+
### Step 2: Locate Relevant Pages
|
|
32
36
|
|
|
33
|
-
If `INDEX.base` exists, read it first
|
|
37
|
+
If `INDEX.base` exists, read it first for page discovery and the compiled knowledge map:
|
|
34
38
|
|
|
35
39
|
```bash
|
|
36
|
-
obsidian read "INDEX"
|
|
40
|
+
obsidian read file="INDEX.base"
|
|
37
41
|
```
|
|
38
42
|
|
|
39
|
-
|
|
43
|
+
Read `SCHEMA.md` when you need the tag taxonomy, domain rules, or agent directory conventions.
|
|
44
|
+
|
|
45
|
+
Then search for relevant pages:
|
|
40
46
|
|
|
41
47
|
```bash
|
|
42
48
|
obsidian search "<key concept>"
|
|
@@ -44,25 +50,28 @@ obsidian search "<key concept>"
|
|
|
44
50
|
|
|
45
51
|
Search for each key concept mentioned in the question. Combine results across concepts.
|
|
46
52
|
|
|
47
|
-
### Step 3: Read Relevant
|
|
53
|
+
### Step 3: Read Relevant Pages
|
|
48
54
|
|
|
49
55
|
For each promising result, read the full content:
|
|
50
56
|
|
|
51
57
|
```bash
|
|
52
|
-
obsidian read "
|
|
58
|
+
obsidian read file="entities/some-page.md"
|
|
53
59
|
```
|
|
54
60
|
|
|
55
61
|
Prioritize:
|
|
56
|
-
-
|
|
57
|
-
-
|
|
58
|
-
-
|
|
62
|
+
- Agent pages in `entities/`, `concepts/`, `comparisons/`, `queries/`
|
|
63
|
+
- Pages with matching tags or domain
|
|
64
|
+
- Pages with `status: reviewed` (over `draft`)
|
|
65
|
+
- Recent pages (higher `updated` date)
|
|
66
|
+
|
|
67
|
+
Also read user source notes when the question requires original context.
|
|
59
68
|
|
|
60
69
|
### Step 4: Synthesize Answer
|
|
61
70
|
|
|
62
|
-
Combine evidence from all relevant
|
|
71
|
+
Combine evidence from all relevant pages into a clear, structured answer:
|
|
63
72
|
|
|
64
73
|
- **Direct answer first** — address the question directly
|
|
65
|
-
- **Supporting evidence** — cite specific
|
|
74
|
+
- **Supporting evidence** — cite specific pages with wikilinks and brief quotes
|
|
66
75
|
- **Context** — explain how the evidence connects
|
|
67
76
|
- **Uncertainties** — flag gaps where the vault doesn't have enough information
|
|
68
77
|
|
|
@@ -77,9 +86,9 @@ Every claim must be backed by at least one vault note. Do not use general knowle
|
|
|
77
86
|
|
|
78
87
|
## Evidence
|
|
79
88
|
|
|
80
|
-
- **[[
|
|
81
|
-
- **[[
|
|
82
|
-
- **[[
|
|
89
|
+
- **[[Page A]]**: "<relevant quote>"
|
|
90
|
+
- **[[Page B]]**: "<relevant quote>"
|
|
91
|
+
- **[[Page C]]**: "<relevant quote>"
|
|
83
92
|
|
|
84
93
|
## Context
|
|
85
94
|
|
|
@@ -94,6 +103,7 @@ Every claim must be backed by at least one vault note. Do not use general knowle
|
|
|
94
103
|
- Consider exploring: "..."
|
|
95
104
|
- Run `/trace topic="X"` to see how this evolved
|
|
96
105
|
- Run `/connect from="A" to="B"` to understand the relationship
|
|
106
|
+
- If the vault lacks pages for key entities or concepts, run `/cook` to compile knowledge from source notes
|
|
97
107
|
```
|
|
98
108
|
|
|
99
109
|
### Step 6: Save (Optional)
|
|
@@ -107,21 +117,12 @@ If the user confirms, save the answer with frontmatter:
|
|
|
107
117
|
```yaml
|
|
108
118
|
---
|
|
109
119
|
title: "Answer: <topic>"
|
|
110
|
-
note_type: literature
|
|
111
|
-
type: reference
|
|
112
|
-
domain: <inferred>
|
|
113
120
|
date: <today>
|
|
114
121
|
tags: [qa, <topic>]
|
|
115
122
|
---
|
|
116
123
|
```
|
|
117
124
|
|
|
118
|
-
Use `obsidian create` to save
|
|
119
|
-
|
|
120
|
-
```bash
|
|
121
|
-
obsidian create name="Answer: <topic>" content="<frontmatter + content>" silent
|
|
122
|
-
```
|
|
123
|
-
|
|
124
|
-
Ask the user where they'd like it saved (root or a specific directory).
|
|
125
|
+
Use `obsidian create` to save. Ask the user where they'd like it saved.
|
|
125
126
|
|
|
126
127
|
## Key Principles
|
|
127
128
|
|
package/src/skills/challenge.md
CHANGED
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: challenge
|
|
3
|
-
description:
|
|
3
|
+
description: >
|
|
4
|
+
Pressure-tests beliefs against vault evidence. Finds contradictions, position changes,
|
|
5
|
+
unstated assumptions, and weak points in arguments. Use when the user wants to question
|
|
6
|
+
a decision, test a hypothesis, or find flaws in their reasoning.
|
|
4
7
|
---
|
|
5
8
|
|
|
6
|
-
# /challenge — Pressure
|
|
9
|
+
# /challenge — Pressure Test
|
|
7
10
|
|
|
8
|
-
You are a
|
|
11
|
+
You are a respectful adversary. Your job is to find the weak points in a belief, decision, or argument — not to be destructive, but to strengthen the user's thinking by exposing vulnerabilities they may have missed.
|
|
9
12
|
|
|
10
13
|
## Prerequisites Check
|
|
11
14
|
|
|
@@ -13,162 +16,117 @@ You are a constructive critic. Your job is to take a belief, assumption, or deci
|
|
|
13
16
|
obsidian --version
|
|
14
17
|
```
|
|
15
18
|
|
|
16
|
-
If this fails, STOP and display the Obsidian CLI availability message (see /
|
|
17
|
-
|
|
18
|
-
## Tool Selection
|
|
19
|
-
|
|
20
|
-
Use `obsidian` CLI for content operations (read, search, backlinks, properties, tags). Use BYOAO tools (`byoao_search_vault`, `byoao_graph_health`) when Obsidian CLI is unavailable or for graph-level structural queries.
|
|
19
|
+
If this fails, STOP and display the Obsidian CLI availability message (see /prep).
|
|
21
20
|
|
|
22
21
|
## Parameters
|
|
23
22
|
|
|
24
|
-
- **
|
|
25
|
-
- **
|
|
26
|
-
- **output** (optional): Save the challenge analysis as a note.
|
|
23
|
+
- **claim** (required): The belief, decision, or argument to challenge.
|
|
24
|
+
- **scope** (optional): `all` (full vault) or a specific directory/page. Default: `all`.
|
|
27
25
|
|
|
28
26
|
## Process
|
|
29
27
|
|
|
30
|
-
### Step 1:
|
|
31
|
-
|
|
32
|
-
Parse the user's input and restate the belief clearly:
|
|
33
|
-
|
|
34
|
-
> "The belief being tested: **{clear statement}**"
|
|
28
|
+
### Step 1: Understand the Claim
|
|
35
29
|
|
|
36
|
-
|
|
30
|
+
Clarify what exactly is being challenged:
|
|
31
|
+
- What is the core assertion?
|
|
32
|
+
- What assumptions does it rest on?
|
|
33
|
+
- What would falsify it?
|
|
37
34
|
|
|
38
|
-
|
|
39
|
-
obsidian read "<note>"
|
|
40
|
-
```
|
|
35
|
+
If the claim is ambiguous, ask the user to clarify before proceeding.
|
|
41
36
|
|
|
42
37
|
### Step 2: Find Supporting Evidence
|
|
43
38
|
|
|
44
|
-
First, be fair — find notes that support the belief:
|
|
45
|
-
|
|
46
39
|
```bash
|
|
47
|
-
obsidian search "<key terms from
|
|
40
|
+
obsidian search "<key terms from claim>"
|
|
48
41
|
```
|
|
49
42
|
|
|
50
|
-
Read notes
|
|
51
|
-
-
|
|
52
|
-
-
|
|
53
|
-
-
|
|
54
|
-
|
|
55
|
-
### Step 3: Find Counter-Evidence
|
|
56
|
-
|
|
57
|
-
Now actively look for contradictions:
|
|
58
|
-
|
|
59
|
-
**Direct contradictions** — Notes that explicitly state the opposite.
|
|
60
|
-
|
|
61
|
-
**Changed positions** — Run a temporal analysis (like /trace):
|
|
62
|
-
- Did the user ever hold a different view?
|
|
63
|
-
- When did it change? What triggered it?
|
|
64
|
-
- Was the change based on new evidence or assumption?
|
|
65
|
-
|
|
66
|
-
**Unstated assumptions** — What does the belief take for granted?
|
|
67
|
-
- "This assumes that {X} will remain true"
|
|
68
|
-
- "This assumes that {person/team} agrees"
|
|
69
|
-
- "This assumes the current constraints won't change"
|
|
70
|
-
|
|
71
|
-
**Missing perspectives** — Whose viewpoint is absent?
|
|
72
|
-
- "No notes consider the user/customer perspective"
|
|
73
|
-
- "The cost analysis only covers engineering, not operations"
|
|
74
|
-
|
|
75
|
-
**Survivorship bias** — Is the vault only tracking successes?
|
|
76
|
-
- "Three similar initiatives are documented, all framed positively. Are there failed attempts that weren't documented?"
|
|
77
|
-
|
|
78
|
-
### Step 4: Assess Confidence Level
|
|
43
|
+
Read relevant notes and agent pages. Identify:
|
|
44
|
+
- Notes that explicitly support the claim
|
|
45
|
+
- Notes that provide indirect support (data, observations)
|
|
46
|
+
- The strength of each piece of evidence
|
|
79
47
|
|
|
80
|
-
|
|
48
|
+
### Step 3: Find Contradicting Evidence
|
|
81
49
|
|
|
82
|
-
|
|
83
|
-
|-------|-------------|
|
|
84
|
-
| **Strong** | Consistent support across notes, no meaningful counter-evidence, assumptions are reasonable |
|
|
85
|
-
| **Moderate** | Good support but some counter-evidence exists, or key assumptions are untested |
|
|
86
|
-
| **Weak** | Significant counter-evidence, contradictions over time, or critical unstated assumptions |
|
|
87
|
-
| **Contradicted** | The vault's own history provides stronger evidence against the belief |
|
|
50
|
+
This is the core of /challenge. Search for:
|
|
88
51
|
|
|
89
|
-
|
|
52
|
+
1. **Direct contradictions** — Notes that explicitly state the opposite
|
|
53
|
+
```bash
|
|
54
|
+
obsidian search "not <term>" OR "instead of <term>" OR "changed from <term>"
|
|
55
|
+
```
|
|
90
56
|
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
**Confidence level**: {Strong / Moderate / Weak / Contradicted}
|
|
95
|
-
|
|
96
|
-
---
|
|
97
|
-
|
|
98
|
-
## The Belief
|
|
99
|
-
|
|
100
|
-
{Restated belief in the user's own words, citing the source note if applicable}
|
|
101
|
-
|
|
102
|
-
## Supporting Evidence ({N} notes)
|
|
103
|
-
|
|
104
|
-
- **[[Note]]**: "{quote supporting the belief}"
|
|
105
|
-
- **[[Note]]**: "{quote}"
|
|
57
|
+
2. **Implicit contradictions** — Notes that describe a situation incompatible with the claim
|
|
58
|
+
- Read pages with shared tags but different conclusions
|
|
59
|
+
- On related `entities/` and `concepts/` pages, check optional `contradictions` frontmatter (v2: YAML list of other agent page names documenting conflicting claims — see `/cook` Contradiction Handling)
|
|
106
60
|
|
|
107
|
-
|
|
61
|
+
3. **Position changes over time** — Notes that show the user changed their mind
|
|
62
|
+
```bash
|
|
63
|
+
obsidian search "actually" OR "turns out" OR "reconsidered" OR "reversed"
|
|
64
|
+
```
|
|
108
65
|
|
|
109
|
-
|
|
66
|
+
4. **Weasel words** — Notes that express uncertainty about aspects the claim treats as certain
|
|
67
|
+
- "might", "probably", "not sure", "need to verify"
|
|
68
|
+
- These indicate the claim is stronger than the evidence supports
|
|
110
69
|
|
|
111
|
-
|
|
112
|
-
**Why this matters**: {explanation}
|
|
70
|
+
### Step 4: Identify Unstated Assumptions
|
|
113
71
|
|
|
114
|
-
|
|
72
|
+
For the claim to be true, what else must be true?
|
|
115
73
|
|
|
116
|
-
-
|
|
117
|
-
-
|
|
118
|
-
-
|
|
74
|
+
- Technical assumptions (about systems, tools, constraints)
|
|
75
|
+
- People assumptions (about availability, skills, priorities)
|
|
76
|
+
- Temporal assumptions (about deadlines, sequencing, stability)
|
|
77
|
+
- External assumptions (about market, users, dependencies)
|
|
119
78
|
|
|
120
|
-
|
|
79
|
+
Check if the vault evidence supports each assumption.
|
|
121
80
|
|
|
122
|
-
|
|
123
|
-
Evidence: {what the vault says or doesn't say}
|
|
81
|
+
### Step 5: Assess Evidence Strength
|
|
124
82
|
|
|
125
|
-
|
|
83
|
+
Rate the overall case:
|
|
126
84
|
|
|
127
|
-
|
|
85
|
+
| Strength | Meaning |
|
|
86
|
+
|----------|---------|
|
|
87
|
+
| Strong | Multiple independent sources agree, no contradictions |
|
|
88
|
+
| Moderate | Some support, minor gaps or contradictions |
|
|
89
|
+
| Weak | Limited evidence, significant contradictions or gaps |
|
|
90
|
+
| Unknown | Vault doesn't have enough information |
|
|
128
91
|
|
|
129
|
-
|
|
92
|
+
### Step 6: Present the Challenge
|
|
130
93
|
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
{2-3 paragraphs — fair assessment of how the belief holds up. Not a yes/no judgment but a nuanced analysis of where it's strong and where it's vulnerable.}
|
|
134
|
-
|
|
135
|
-
## Questions to Sit With
|
|
94
|
+
```markdown
|
|
95
|
+
# Challenge: "{claim}"
|
|
136
96
|
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
3. {Another question}
|
|
97
|
+
## The Claim
|
|
98
|
+
{Restate the claim clearly}
|
|
140
99
|
|
|
141
|
-
##
|
|
100
|
+
## What Rests On This
|
|
101
|
+
{What assumptions does the claim depend on?}
|
|
102
|
+
- {Assumption 1} — {supported / unsupported / contradicted}
|
|
103
|
+
- {Assumption 2} — {supported / unsupported / contradicted}
|
|
142
104
|
|
|
143
|
-
|
|
144
|
-
-
|
|
145
|
-
-
|
|
146
|
-
```
|
|
105
|
+
## Supporting Evidence
|
|
106
|
+
- [[Note A]]: "{quote}"
|
|
107
|
+
- [[Note B]]: "{quote}"
|
|
147
108
|
|
|
148
|
-
|
|
109
|
+
## Challenging Evidence
|
|
110
|
+
- ⚠ [[Note C]]: "{quote that contradicts or weakens the claim}"
|
|
111
|
+
- ⚠ [[Note D]]: "{quote showing uncertainty or alternative view}"
|
|
149
112
|
|
|
150
|
-
|
|
113
|
+
## Position Changes Over Time
|
|
114
|
+
- {date}: [[Note E]] said X
|
|
115
|
+
- {date}: [[Note F]] said Y (contradicts X)
|
|
151
116
|
|
|
152
|
-
|
|
117
|
+
## Weak Points
|
|
118
|
+
1. **{Weak point}**: {why it's weak, which note shows it}
|
|
119
|
+
2. **{Weak point}**: {why it's weak, which note shows it}
|
|
153
120
|
|
|
154
|
-
|
|
121
|
+
## Overall Assessment
|
|
122
|
+
**Evidence strength**: {Strong / Moderate / Weak / Unknown}
|
|
155
123
|
|
|
156
|
-
|
|
157
|
-
---
|
|
158
|
-
title: "Challenge: {Belief}"
|
|
159
|
-
note_type: literature
|
|
160
|
-
type: analysis
|
|
161
|
-
date: <today>
|
|
162
|
-
tags: [challenge, critical-thinking]
|
|
163
|
-
---
|
|
124
|
+
{2-3 sentence summary: what the vault evidence suggests about this claim, what's uncertain, and what would strengthen or weaken the case further}
|
|
164
125
|
```
|
|
165
126
|
|
|
166
|
-
Use `obsidian create` to save. Ask the user where they'd like it saved.
|
|
167
|
-
|
|
168
127
|
## Key Principles
|
|
169
128
|
|
|
170
|
-
- **
|
|
171
|
-
- **
|
|
172
|
-
- **
|
|
173
|
-
- **
|
|
174
|
-
- **Respect the "strong" result**: If a belief holds up well, say so clearly. Not every challenge needs to find problems.
|
|
129
|
+
- **Respectful opposition.** The goal is to strengthen thinking, not to tear it down. Frame challenges as "here's what to consider" not "you're wrong."
|
|
130
|
+
- **Evidence only.** Every challenge must cite specific vault notes. Don't invent external counterarguments.
|
|
131
|
+
- **Surface uncertainty.** If the vault shows doubt or hesitation about aspects the claim treats as certain, highlight this gap.
|
|
132
|
+
- **Obsidian is first workbench.** All note operations go through Obsidian CLI.
|