Chatting with AI
approvedby o1xhack
This plugin has not been manually reviewed by Obsidian staff. Agentic AI chat assistant that reads, edits, and creates notes through natural conversation. Supports Anthropic, OpenAI, and ChatGPT account sign-in.
Chatting with AI
An agentic AI assistant that lives in your Obsidian vault โ same experience on phone, tablet, and desktop.
๐ English ยท ็ฎไฝไธญๆ ยท ็น้ซไธญๆ ยท ๆฅๆฌ่ช
โจ Why?
- Three providers, your choice โ Anthropic API, OpenAI API, or sign in with your ChatGPT account. No marketplace of half-broken providers.
- 14 vault-native tools โ read, edit, search, create, rename, frontmatter, backlinks. The agent goes from idea to changed files without leaving the chat.
- Mobile-parity, by design โ no streaming, no Node-only modules, no localhost callbacks. iOS and Android behave the same as desktop.
- Selection scope โ highlight text in any note, send it to chat, the assistant edits only inside the selection.
- Secrets in the OS keychain โ never in
data.json, never synced across devices.
๐ฌ One conversation, many tools
Ask once, the agent figures out which tools to call:
You: Find every note in /Books that's missing a `rating` property and add `rating: ?`.
Assistant
โ search_vault("/Books") โ 12 files
โ get_properties("Books/Sapiens.md") โ has rating
โ get_properties("Books/Hail Mary.md") โ no rating
โ set_properties("Books/Hail Mary.md", { rating: "?" })
โ ... (5 more)
Done โ added `rating: ?` to 6 notes:
- Books/Hail Mary.md
- Books/Klara and the Sun.md
- ...
The agent reads before it edits, prefers small surgical changes over rewrites, and doesn't re-ask once you confirm.
๐ฏ Selection scope
Highlight text in any note, right-click, choose Send selection to Chat. The selection becomes a pill above the input and the assistant edits only inside the selected range โ leaving the rest of the document byte-identical.
[ pill: "...the introduction was a bit dry, and..." โ ]
You: tighten this โ keep my voice
The agent uses find-and-replace scoped to the selection text. Everything outside the highlight stays untouched.
๐ ๏ธ 14 vault-native tools
| Group | Tools | What they do |
|---|---|---|
| Read | read_document, read_file, search_vault, list_files, get_backlinks, get_properties, get_current_datetime | Open notes/files, search by name and content, browse the tree, find backlinks, read frontmatter, fetch the current time in your locale. |
| Write | edit_document, create_file, set_properties | Surgical find-and-replace / insert / full replace; create new notes (parent folders auto-created); safe YAML frontmatter merge or remove. |
| Manage | rename_file, delete_file, open_document, ask_user | Rename or move (links auto-update); move to trash (respects your trash setting); open a file in the editor; pause and ask you when something is ambiguous. |
โ๏ธ Providers
| Provider | Auth | Default model | Notes |
|---|---|---|---|
| Anthropic | API key | Claude Sonnet 4.6 | Adaptive thinking, web search, prompt caching. |
| OpenAI | API key | Codex 5.3 | Responses API, reasoning, web search. |
| ChatGPT account | Sign in with ChatGPT | GPT-5.5 | Uses your ChatGPT plan instead of an OpenAI API key. |
About ChatGPT account login. This provider signs you in with your ChatGPT account and routes requests through the ChatGPT/Codex backend (not
api.openai.com). It requires an active ChatGPT plan with Codex access. The available models mirror the Codex CLI catalog.
๐ Quick start
- Open Settings โ Community plugins โ Browse.
- Search for Chatting with AI.
- Click Install, then Enable.
- Settings โ Chatting with AI โ pick a provider, paste an API key (or click Connect ChatGPT).
- Open the chat from the ribbon icon or the command palette.
๐ฆ Install
Community Plugins (recommended)
This is the default install path now that Chatting with AI is in the official Obsidian Community Plugins directory.
- In Obsidian, open Settings โ Community plugins.
- If prompted, turn off Restricted Mode / turn on community plugins.
- Click Browse and search for Chatting with AI.
- Click Install, then Enable.
Migrating from BRAT
If you previously installed the beta through BRAT, move to the community version once it appears in the plugin browser:
- In Settings โ Community plugins โ Installed plugins, disable Chatting with AI.
- Open BRAT settings and remove
o1xhack/obsidian-chattingfrom the beta plugin list. - Return to Settings โ Community plugins โ Browse and search for Chatting with AI.
- If Obsidian shows it as Installed, open its entry and click Enable. If it shows Install, click Install, then Enable.
- Open Settings โ Chatting with AI and confirm your provider settings are still present.
The plugin migrates data from the old obsidian-chatting folder to chatting-with-ai on first load. If you used a very old beta and the community browser does not recognize it as installed, installing the community version is still safe; the migration runs when the new plugin starts.
Manual release install
- Download
main.js,manifest.json,styles.cssfrom the latest release - Place them in
<vault>/.obsidian/plugins/chatting-with-ai/ - Reload Obsidian and enable Chatting with AI in Community Plugins
Build from source
git clone https://github.com/o1xhack/obsidian-chatting.git
cd obsidian-chatting
npm install
npm run build
Symlink into a test vault:
ln -s "$(pwd)" /path/to/vault/.obsidian/plugins/chatting-with-ai
๐งญ Design principles
| Principle | What it means |
|---|---|
| Mobile is not an afterthought | Every change is validated on iOS and Android. No streaming, no Node-only modules, no localhost callbacks. |
| Three sane providers | Anthropic + OpenAI for stability, ChatGPT account for users who'd rather not manage an API key. |
| Secrets in the keychain | API keys and OAuth credentials go through Obsidian SecretStorage. They never land in data.json, so they never sync to other devices. |
| No vault indexing | Linear search, capped. Predictable, no background work, no memory pressure on phones. |
| Conversation persists | Chat history survives Obsidian restarts. Stored locally in chat-state.json, never synced. |
| Right sidebar on mobile | Slides in from the edge โ your document stays visible underneath. |
๐บ๏ธ Roadmap
- Three providers (Anthropic, OpenAI, ChatGPT account)
- 14 vault-native tools
- iOS / Android parity
- Selection scope
- Official Obsidian Community Plugins listing
- Multi-conversation history with archive / search
- Image attachments where the provider supports them
- More upstream provider models picked up automatically as they ship
Have a request? Open an issue.
โ FAQ
Will my notes be uploaded somewhere?
Only what the agent needs for the current turn. When you ask a question, the agent decides which tools to call โ read_document, search_vault, etc. โ and the contents fetched by those calls (plus the active note context) are sent to your chosen provider. Nothing is uploaded in the background. There is no vault index.
Does it really work on mobile?
Yes โ that's the design constraint everything else is built around. Requests go through Obsidian's requestUrl() (mobile WebViews enforce CORS), there's no streaming, no Node-only modules, no localhost callback for OAuth. iOS and Android run the same code path as desktop.
Is the ChatGPT account login free?
It uses your existing ChatGPT plan (Plus, Pro, Team, Enterprise) โ there's no separate billing. You need an active plan with Codex access. The plugin doesn't talk to api.openai.com; it talks to the same backend the Codex CLI uses.
Can you add provider X?
Probably not โ keeping the provider list small is a deliberate choice. Two API providers cover the major ecosystems, and ChatGPT account login covers the "I just have a ChatGPT plan" case. Adding more would mean more permutations to validate on mobile.
Where is chat history stored? Will it sync?
Locally in <vault>/.obsidian/plugins/chatting-with-ai/chat-state.json. It is not synced by Obsidian Sync (plugin data files are excluded by default). API keys live in the OS keychain via SecretStorage and are also not synced.
๐ค Contributing
Issues and PRs welcome. Before opening a PR:
- Run
npx tsc --noEmitandnpm run svelte-check - Test on at least one mobile platform (iOS or Android) โ the mobile-parity rule is real
- For larger changes, open an issue first to align on direction
๐ Acknowledgements
Originally derived from omarshahine/obsidian-chat (MIT). The original copyright is preserved in LICENSE. Chatting with AI is now an independent project with its own roadmap โ major rewrites include the agent loop, mobile-parity work, the ChatGPT account provider, and the selection-scope feature.
๐ License
MIT.
Author: Yuxiao (o1xhack) ยท app.o1xhack.com
For plugin developers
Search results and similarity scores are powered by semantic analysis of your plugin's README. If your plugin isn't appearing for searches you'd expect, try updating your README to clearly describe your plugin's purpose, features, and use cases.