@elizaos/plugin-obsidian
An Obsidian plugin for ELIZA OS that provides seamless integration with Obsidian vaults, enabling powerful file and note management capabilities.
Features​
-
Deep traversal of Obsidian notes:
- Implementing hierarchical note structure analysis
- Enabling traversal of note links and backlinks
- Storing hierarchy data in memory for efficient access
-
Advanced search functionality:
- Full-text search across all vault files
- Support for regex patterns and context-aware searches
- Integration with Obsidian's native search capabilities using Obsidian's Rest API
-
Obsidian memory store integration:
- Building and maintaining a knowledge base from vault notes
- Implementing efficient data structures for quick retrieval
-
Naval database integration as an example:
- Demonstrating how to import and structure obsidian notes in the agent memory
- Showcasing integration of Naval's wisdom and quotes
- Creating a knowledge base from Naval's vault notes for the agent
- Naval's character json file is included in the PR for reference (found in the example directory)
Vault Operations​
-
List Files
- Get all files in the vault
// List all files
const files = await obsidian.listFiles(); // Example: "List all files" -
Directory Management
- List directory contents
// List directory contents
const contents = await obsidian.listDirectory('path/to/dir'); // Example: "List directory PATH" or "ls PATH"
Note Management​
-
Note Retrieval
- Get note content and metadata
- Support for frontmatter parsing
// Get a note with its content
const note = await obsidian.getNote('path/to/note.md'); // Example: "Get note PATH" -
Deep Traversal
- Build hierarchical note structures
- Store hierarchy data in memory
- Traverse note links and backlinks
// Traverse notes links
const hierarchy = buildLinkHierarchy('path/to/start-note.md'); // Example: "Map links in PATH" -
Create Knowledge Bases
- Build memory knowledge base from vault notes
// Build knowledge base
const knowledgeBase = await obsidian.createMemoriesFromFiles(); // Example: "Create knowledge base"
Search Capabilities​
-
Full-Text Search
- Search across all vault files
- Support for regex patterns
- Support for context search
- Support for frontmatter search
// Search in vault
const results = await obsidian.search('query');
// Examples: "Search QUERY" or "find notes with 'YOUR QUERY'" or "search notes named 'FILENAME'"
File Operations​
-
Read Files
- Read files in the Obsidian Vault
// Open a file in Obsidian
await obsidian.readFile('DOCUMENTS/report.txt'); // Example: "Read DOCUMENTS/report.txt" -
Create/Save Files
- Create new files with automatic directory creation
- Save content to existing files
- Support for various file types
// Create or update a file
await obsidian.saveFile('DOCUMENTS/report.txt', 'Content', true); // Example: "Save DOCUMENTS/report.txt" -
Open Files
- Open files in the Obsidian Vault
- Seamless integration with Obsidian's Rest API
// Open a file in Obsidian
await obsidian.openFile('DOCUMENTS/report.txt'); // Example: "Open DOCUMENTS/report.txt" -
Update Files
- Update existing files without creating new ones
- Line-specific updates supported
// Update an existing file
await obsidian.patchFile('DOCUMENTS/report.txt', 'New content'); // Example: "Update DOCUMENTS/report.txt"
Installation​
npm install @elizaos/plugin-obsidian
# or
yarn add @elizaos/plugin-obsidian
# or
bun add @elizaos/plugin-obsidian
Configuration​
The plugin requires the following character secret settings:
{
"settings": {
"secrets": {
"OBSIDIAN_API_TOKEN": "your-obsidian-api-token",
"OBSIDIAN_API_PORT": "your-obsidian-api-port", // Optional (default: 27123)
"OBSIDIAN_API_URL": "https://your-obsidian-api-url" // Optional (default: "http://127.0.0.1:27123")
}
// other settings...
}
}
Usage​
Import and register the plugin in your Eliza agent configuration:
import { obsidianPlugin } from '@elizaos/plugin-obsidian';
export default {
plugins: [
// other plugins...
getSecret(character, 'OBSIDIAN_API_TOKEN') ? obsidianPlugin : null,
// other plugins...
],
};
Development​
# Build the plugin
bun build
# Run in development mode
bun dev
# Run tests
bun test
# Run linting
bun lint
Actions​
The plugin provides several actions that can be used with ELIZA OS:
SAVE_FILE
: Create or update filesOPEN_FILE
: Open files in ObsidianUPDATE_FILE
: Update existing filesGET_NOTE
: Retrieve note contentNOTE_TRAVERSAL
: Build note hierarchiesSEARCH
: Search vault contentsLIST_FILES
: List vault filesLIST_DIRECTORY
: List directory contentsCREATE_KNOWLEDGE
: Generate knowledge basesGET_ACTIVE_NOTE
: Get current noteSUMMARIZE_ACTIVE_NOTE
: Summarize current note
Error Handling​
The plugin provides detailed error messages and proper error handling:
try {
await obsidian.saveFile('path/to/file', 'content');
} catch (error) {
if (error.code === 'FILE_NOT_FOUND') {
// Handle file not found
}
// Handle other errors
}
Contributing​
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature
) - Commit your changes (
git commit -m 'Add amazing feature'
) - Push to the branch (
git push origin feature/amazing-feature
) - Open a Pull Request
License​
This project is licensed under the MIT License - see the LICENSE file for details.
Support​
For support, please:
- Check the documentation
- Open an issue in the repository
- Join our Discord community