sharkello126 downloadsSync your vault with Notion — preserves folder hierarchy, markdown formatting, internal links, metadata, and attachments.
Synchronize your entire Obsidian vault to Notion — preserving folder hierarchy, markdown formatting, internal links, frontmatter metadata, and attachments.
[[wikilinks]] are resolved to their synced Notion page URLs![[file.png]]) can be uploaded to Notion via a configurable upload endpointhttps://notion.so/Your-Page-Title-abc123def456...Open Settings → Notion Sync and fill in:
| Setting | Description |
|---|---|
| Notion API Token | Your integration secret (secret_...) |
| Root Notion Page ID | The page ID from step 2 |
| Sync Mode | Manual / On Save / Scheduled / Current File |
| Sync Attachments | Upload images and file embeds |
| Sync Metadata | Push YAML frontmatter as page properties |
| Sync Interval | How often to auto-sync (minutes, scheduled mode only) |
| Attachment Upload URL | Optional external endpoint for file uploads |
Click Test Connection to verify everything is working.
| Mode | Behavior |
|---|---|
| Manual | Only syncs when you run a command |
| On Save | Syncs the current file every time you save |
| Scheduled | Syncs the entire vault at a set interval |
| Current File | Syncs only the currently open file on demand |
All commands are available via the Command Palette (Cmd/Ctrl + P):
| Command | Description |
|---|---|
| Sync entire vault to Notion | Full sync of all notes and folders |
| Sync current note to Notion | Push only the currently open note |
| Sync changed files to Notion | Incremental sync — only changed files |
| Rebuild Notion hierarchy | Re-create the folder structure in Notion without re-syncing content |
| Open sync log | View a detailed log of all sync operations |
The following Obsidian/Markdown elements are converted to native Notion blocks:
#, ##, ###)inline code- [ ] / - [x])>)---)![[...]])[[Note Name]]) resolved to Notion URLsBy default, attachment embeds are converted to placeholder callout blocks in Notion. To enable real image uploads:
The plugin will POST the file binary to this URL and use the returned url field as the Notion image source.
Your Notion API token and page IDs are stored locally in data.json inside your vault and are never sent anywhere except directly to the official Notion API (api.notion.com). This file is excluded from version control by the plugin's .gitignore.
main.js and manifest.json into your vault's plugin folder:.obsidian/plugins/obsidian-notion-sync/Pull requests and issues are welcome. Please open an issue before starting any large change so we can discuss the approach.