secondbrain-init
npx skills add https://github.com/sergio-bershadsky/ai --skill secondbrain-init
Agent 安装分布
Skill 文档
Secondbrain Project Scaffolding
Scaffold a complete knowledge management system with microdatabases, VitePress portal, and Claude automation.
Overview
Initialize a new secondbrain project with:
- Microdatabase architecture (YAML + JSON Schema validation)
- VitePress documentation portal (custom theme, Vue components)
- Configurable entity types (ADRs, Discussions, Notes, Tasks, Custom)
- Claude automation (hooks, maximum freedom settings)
Workflow
Step 1: Gather Project Information
Ask the user for:
- Project name (kebab-case, e.g.,
my-knowledge-base) - Target directory (default:
./<project-name>) - Use case (optional context for customization):
- Personal knowledge base
- Project documentation
- Team collaboration
Step 2: Select Entity Types
Present entity selection with checkboxes:
## Entity Selection
Which entities would you like to enable?
[x] ADRs (Architecture Decision Records)
- Numbered decisions with status workflow
- Category-based numbering ranges
[x] Discussions (Meeting notes, conversations)
- Monthly partitioned records
- Participant tracking
[x] Notes (General knowledge capture)
- Date-based IDs
- Tag support
[ ] Tasks (Action items, todo tracking)
- Sequential numbering
- Priority and due dates
Would you like to define a custom entity type? (y/n)
Step 3: Configure Semantic Search
Present search configuration options:
## Search Configuration
Which semantic search would you like to enable?
[ ] qmd (Claude Code search)
- CLI-based semantic search for AI
- Requires: bun/npm install -g qmd (~1.5GB models)
- Best for: Local development, Claude Code integration
[ ] Orama (VitePress browser search)
- Client-side semantic search for humans
- Adds ~30MB to browser (on-demand model loading)
- Best for: Static sites, offline-capable portals
[x] Both (Recommended)
- Dual index: qmd for Claude, Orama for browser
- Same semantic search quality for AI and humans
[ ] None (Skip search)
- Use basic VitePress search (keyword only)
- Can add semantic search later with /secondbrain-search-init
Based on selection:
| Selection | Actions |
|---|---|
| qmd | Create .claude/search/, generate qmd.config.json, add search hook |
| Orama | Add Orama deps to package.json, generate SearchBox.vue, generate build script |
| Both | All of the above |
| None | Skip search setup, use VitePress native search |
Step 5: Configure Maximum Freedom Settings
CRITICAL: Always propose creating .claude/settings.local.json with maximum permissions:
{
"$schema": "https://json.schemastore.org/claude-code-settings.json",
"_comment": "Secondbrain project - maximum freedom for knowledge management",
"permissions": {
"allow_web_search": true,
"allow_web_fetch": ["*"],
"allow_read": ["~/**", "/tmp/**"],
"allow_bash": ["*"],
"auto_approve_write": ["<project_path>/docs/**"]
}
}
Show the settings and ask for confirmation before proceeding.
Step 6: Generate Scaffolding
Create the following structure:
<project-name>/
âââ .claude/
â âââ settings.local.json # Max freedom permissions + hooks
â âââ data/
â â âââ config.yaml # Project configuration
â â âââ adrs/ # (if enabled)
â â â âââ schema.yaml
â â â âââ records.yaml
â â âââ discussions/ # (if enabled)
â â â âââ schema.yaml
â â â âââ YYYY-MM.yaml # Current month
â â âââ notes/ # (if enabled)
â â â âââ schema.yaml
â â â âââ records.yaml
â â âââ tasks/ # (if enabled)
â â âââ schema.yaml
â â âââ records.yaml
â âââ lib/
â â âââ tracking.py # CRUD library with validation
â âââ hooks/
â â âââ freshness-check.py
â â âââ sidebar-check.py
â â âââ session-context.py
â â âââ search-index-update.py # (if qmd enabled)
â âââ search/ # (if qmd enabled)
â âââ (qmd index files)
âââ docs/
â âââ .vitepress/
â â âââ config.ts # Navigation, sidebar, plugins
â â âââ theme/
â â â âââ index.ts
â â â âââ Layout.vue # Giscus comments
â â â âââ custom.css
â â â âââ components/
â â â âââ EntityTable.vue
â â â âââ SearchBox.vue # (if Orama enabled)
â â âââ data/
â â âââ <entity>.data.ts # Per enabled entity
â âââ index.md # Home page
â âââ adrs/ # (if enabled)
â â âââ index.md
â â âââ TEMPLATE.md
â âââ discussions/ # (if enabled)
â â âââ index.md
â â âââ TEMPLATE.md
â âââ notes/ # (if enabled)
â â âââ index.md
â âââ tasks/ # (if enabled)
â âââ index.md
âââ package.json # VitePress dependencies
âââ qmd.config.json # (if qmd enabled)
âââ CLAUDE.md # Project instructions
âââ .gitignore
Step 7: Generate Files
For each enabled entity, generate from templates in ${CLAUDE_PLUGIN_ROOT}/templates/:
-
Microdatabase files:
config.yamlfromscaffolding/microdatabase/config.yaml.tmpl- Entity
schema.yamlfromentities/<entity>/schema.yaml - Entity
records.yamlinitialized empty
-
VitePress files:
config.tsfromscaffolding/vitepress/config.ts.tmpl- Theme files from
scaffolding/vitepress/theme/ - Data loaders from
scaffolding/vitepress/data/
-
Documentation:
- Home page from
scaffolding/docs/index.md.tmpl - Entity index pages from
scaffolding/docs/entity-index.md.tmpl - Templates from
entities/<entity>/TEMPLATE.md
- Home page from
-
Automation:
settings.local.jsonfromscaffolding/claude/settings.local.json.tmpltracking.pyfromscaffolding/lib/tracking.py.tmpl- Hooks from
hooks/(copy to project)
-
Search (if enabled):
- qmd:
qmd.config.jsonfromscaffolding/search/qmd.config.json.tmpl - qmd: Copy
search-index-update.pyhook - Orama:
SearchBox.vuefromscaffolding/vitepress/theme/components/SearchBox.vue.tmpl - Orama:
build-search-index.tsfromscaffolding/vitepress/search/build-search-index.ts.tmpl - Orama: Add dependencies to
package.json
- qmd:
Step 8: Show Summary
## Secondbrain Created Successfully!
**Project:** my-knowledge-base
**Location:** /path/to/my-knowledge-base
**Entities:** ADRs, Discussions, Notes
### Structure Created
.claude/
âââ settings.local.json â Maximum freedom permissions
âââ data/ â Microdatabases with schemas
âââ lib/tracking.py â CRUD operations
âââ hooks/ â Automation hooks
docs/
âââ .vitepress/ â Custom theme with EntityTable
âââ adrs/ â Decision records
âââ discussions/ â Meeting notes
âââ notes/ â Knowledge capture
### Next Steps
1. Navigate to project:
cd my-knowledge-base
2. Install dependencies:
npm install
3. Start development server:
npm run docs:dev
4. Create your first decision:
/secondbrain-adr infrastructure my-first-decision
5. Add a note:
/secondbrain-note my-first-note
### Available Commands
- /secondbrain-search <query> â Semantic search (if enabled)
- /secondbrain-adr <category> <title> â Create ADR
- /secondbrain-note <title> â Create note
- /secondbrain-discussion <who> <topic> â Document discussion
- /secondbrain-freshness â Check what needs attention
- /secondbrain-entity <name> â Add custom entity type
- /secondbrain-search-init â Enable semantic search later
Template Variables
When generating files, replace these variables:
| Variable | Description |
|---|---|
{{project_name}} |
Project name (kebab-case) |
{{project_path}} |
Absolute path to project |
{{description}} |
Project description |
{{date}} |
Current date (YYYY-MM-DD) |
{{timestamp}} |
Current ISO timestamp |
{{year_month}} |
Current year-month (YYYY-MM) |
{{entities}} |
Array of enabled entity configs |
Entity Configuration
Each entity has standard configuration:
<entity_slug>:
enabled: true
label: "Entity Label"
singular: "Entity"
doc_path: docs/<entity_slug>
freshness:
stale_after_days: 30
Additional Resources
Reference Files
For detailed entity schemas and templates:
references/entity-schemas.mdâ Predefined entity schema definitions
Related Skills
- secondbrain-search â Semantic search your knowledge base
- secondbrain-search-init â Enable search on existing project
- secondbrain-entity â Add custom entity types
- secondbrain-adr â Create Architecture Decision Records
- secondbrain-note â Create notes
- secondbrain-task â Create tasks
- secondbrain-discussion â Document discussions
- secondbrain-freshness â Freshness report