Files
2025-11-30 08:35:59 +08:00

304 lines
8.7 KiB
Markdown

---
name: obsidian-manager
description: Manage Obsidian vault for persistent knowledge storage, search, and retrieval
triggers:
- "save to obsidian"
- "search my notes"
- "find in vault"
- "check my readwise"
- "search readwise"
- "search snipd"
- "check my highlights"
- "create note"
- "add to obsidian"
- "what did I read about"
- "what podcasts mentioned"
allowed-tools: Read, Write, Bash, Glob, Grep
version: 0.1.0
---
# Obsidian Manager Skill
Manage the user's Obsidian vault as a persistent second brain. Read existing knowledge, write new content, and search across years of highlights and notes.
## Vault Configuration
**Path:** `/Users/hagelk/Library/Mobile Documents/iCloud~md~obsidian/Documents/Personal_Notes/`
**Write Mode:** Auto-create new files, confirm before updating existing files.
## Vault Structure
```
Personal_Notes/
├── Geoffrey/ # Geoffrey-generated content
│ ├── Research/ # Research task outputs
│ ├── Reports/ # Generated reports and artifacts
│ │ ├── PSD/ # Peninsula School District reports
│ │ │ ├── Discipline/ # Discipline reports and infographics
│ │ │ ├── Enrollment/ # Enrollment reports
│ │ │ └── {topic}/ # Other PSD topics
│ │ ├── HRG/ # Hat Rack Group (consulting LLC) reports
│ │ │ └── {topic}/ # HRG topics
│ │ ├── Personal/ # Personal reports
│ │ │ └── {topic}/ # Personal topics
│ │ └── {org}/ # Other organizations as needed
│ ├── Daily-Logs/ # Session summaries
│ ├── Learnings/ # Extracted patterns
│ └── Decisions/ # Major decisions with rationale
├── Meetings/ # Meeting notes (YYYY-MM-DD format)
├── People/ # Contact profiles with metadata
├── Readwise/ # Synced highlights (368 articles, 34 books)
│ ├── Articles/
│ ├── Books/
│ ├── Podcasts/
│ └── Tweets/
├── Snipd/ # Podcast highlights (58+ episodes)
│ └── Data/ # Podcast folders > episodes
└── Templates/ # Note templates
```
## Scripts
All scripts use Python via `uv run` with inline dependencies.
### Search Scripts
#### search.py - General Vault Search
```bash
uv run scripts/search.py "query" [folder] [--limit N]
```
Search across the vault for keyword matches. Returns file paths and matching excerpts.
**Examples:**
```bash
# Search entire vault
uv run scripts/search.py "prompt engineering"
# Search specific folder
uv run scripts/search.py "leadership" People
# Limit results
uv run scripts/search.py "AI" Readwise/Articles --limit 10
```
#### search-readwise.py - Search Highlights
```bash
uv run scripts/search-readwise.py "query" [--author "name"] [--category articles|books|podcasts]
```
Search Readwise highlights by topic, author, or category.
**Examples:**
```bash
# Search by topic
uv run scripts/search-readwise.py "second brain"
# Search specific author
uv run scripts/search-readwise.py "AI" --author "Andrej Karpathy"
# Search books only
uv run scripts/search-readwise.py "habits" --category books
```
#### search-snipd.py - Search Podcast Transcripts
```bash
uv run scripts/search-snipd.py "query" [--show "podcast name"]
```
Search Snipd podcast transcripts and snips.
**Examples:**
```bash
# Search all podcasts
uv run scripts/search-snipd.py "machine learning"
# Search specific show
uv run scripts/search-snipd.py "leadership" --show "Huberman Lab"
```
### Creation Scripts
#### create-note.py - Create New Note
```bash
uv run scripts/create-note.py "title" "content" [--folder Geoffrey/Research] [--tags tag1,tag2] [--related "[[Note]]"]
```
Create a new note with proper frontmatter and optional backlinks.
**Examples:**
```bash
# Create research note
uv run scripts/create-note.py "AI Model Comparison" "Content here..." --folder Geoffrey/Research --tags research,ai
# Create with backlinks
uv run scripts/create-note.py "Meeting Notes" "Content..." --folder Meetings --related "[[John Smith]],[[Project Alpha]]"
```
#### open-in-obsidian.py - Open Note in Obsidian
```bash
uv run scripts/open-in-obsidian.py "path/to/note.md"
```
Opens the specified note in Obsidian using Actions URI.
## Content Routing
**CRITICAL:** When creating content, use these destinations. NEVER dump files directly into `Geoffrey/` - always use proper subfolders.
| Content Type | Folder | Naming Pattern |
|--------------|--------|----------------|
| Research results | `Geoffrey/Research/` | `YYYY-MM-DD-topic.md` |
| **Reports** | `Geoffrey/Reports/{org}/{topic}/` | Descriptive name with date |
| **Images/Infographics** | Same as parent report | `Descriptive Name YYYY-MM-DD.png` |
| Meeting notes | `Meetings/` | `Topic - YYYY-MM-DD.md` |
| Daily summaries | `Geoffrey/Daily-Logs/` | `YYYY-MM-DD.md` |
| Learnings | `Geoffrey/Learnings/` | `topic-slug.md` |
| Decisions | `Geoffrey/Decisions/` | `YYYY-MM-DD-decision.md` |
| Person updates | `People/` | Existing file name |
**Naming Rules:**
- All images/infographics MUST include date in filename
- Format: `Descriptive Name YYYY-MM-DD.png` or `Descriptive Name YYYY-MM-DD to YYYY-MM-DD.png` for date ranges
- Example: `Peninsula High School Discipline Report 2025-11-17 to 2025-11-20.png`
**Reports Folder Structure:**
Pattern: `Geoffrey/Reports/{organization}/{topic}/`
Organizations:
- **PSD** - Peninsula School District reports
- `Geoffrey/Reports/PSD/Discipline/`
- `Geoffrey/Reports/PSD/Enrollment/`
- `Geoffrey/Reports/PSD/Attendance/`
- `Geoffrey/Reports/PSD/{topic}/`
- **HRG** - Hat Rack Group (consulting LLC) reports
- `Geoffrey/Reports/HRG/{topic}/`
- **Personal** - Personal reports
- `Geoffrey/Reports/Personal/{topic}/`
- **{org}** - Other organizations as needed
## Frontmatter Standard
All Geoffrey-created notes should include:
```yaml
---
created: 2025-11-23
tags: [geoffrey, research]
source: geoffrey
related:
- "[[Related Note 1]]"
- "[[Related Note 2]]"
---
```
## When to Read from Vault
- **Before research tasks:** Check if user has relevant Readwise highlights or existing notes
- **When people mentioned:** Look up context in People folder
- **For meeting prep:** Find past meetings and related notes
- **For context:** Search Snipd transcripts for podcast discussions on topic
## When to Write to Vault
- **After research:** Save results to `Geoffrey/Research/`
- **Learned patterns:** Extract insights to `Geoffrey/Learnings/`
- **Major decisions:** Document with rationale in `Geoffrey/Decisions/`
- **Session summaries:** Optional daily logs to `Geoffrey/Daily-Logs/`
## Creating Backlinks
Always create backlinks to existing content:
1. **Search before creating:** Find related notes first
2. **Use wiki-links:** `[[Note Title]]` format
3. **Add to frontmatter:** List in `related:` field
4. **Reference sources:** Link to Readwise/Snipd sources when relevant
**Example:**
```markdown
Based on insights from [[Readwise/Articles/Building a Second Brain]],
and discussed in [[Snipd/Data/Huberman Lab/episode-123]],
the key pattern is...
```
## Readwise Content Format
Readwise notes have this structure:
```yaml
---
Author: "Author Name"
Full Title: "Article Title"
Category: #articles
Summary: "AI-generated summary"
---
## Highlights
- Highlight text with optional tags like [[topic]]
```
## Snipd Content Format
Snipd episodes have rich metadata:
```yaml
---
episode_show: "Podcast Name"
episode_publish_date: 2024-01-15
mentioned_books: ["Book 1", "Book 2"]
snips_count: 5
---
### Snip 1
**Timestamp:** 00:15:30
> Quote text here
**Transcript:** Full context...
```
## Actions URI Integration
Use Actions URI to interact with Obsidian app:
```bash
# Open a note
open "obsidian://actions-uri/note/open?vault=Personal_Notes&file=Geoffrey/Research/note.md"
# Create and open
open "obsidian://actions-uri/note/create?vault=Personal_Notes&file=path&content=..."
```
## Best Practices
1. **Search before creating:** Always check for existing content
2. **Link generously:** Create connections between notes
3. **Use consistent tags:** Match existing tag patterns
4. **Keep notes atomic:** One idea per note in Learnings
5. **Include sources:** Always cite Readwise/Snipd sources
6. **Respect existing structure:** Don't reorganize user's folders
## Output Format
When completing Obsidian operations:
```markdown
## Summary
What was done
## Files
- Created: `path/to/new.md`
- Updated: `path/to/existing.md` (if confirmed)
## Related Content Found
- [[Relevant Note 1]] - why it's relevant
- [[Relevant Note 2]] - why it's relevant
## Next Steps
- Recommendations if any
```