Search...Search plugins and themes...
⌘K
Sign in
  • Get started
  • Download
  • Pricing
  • Enterprise
  • Account
  • Obsidian
  • Overview
  • Sync
  • Publish
  • Canvas
  • Mobile
  • Web Clipper
  • CLI
  • Learn
  • Help
  • Developers
  • Changelog
  • About
  • Roadmap
  • Blog
  • Resources
  • System status
  • License overview
  • Terms of service
  • Privacy policy
  • Security
  • Community
  • Plugins
  • Join the community
  • Discord
  • Forum / 中文论坛
  • Merch store
  • Brand guidelines
Follow us
DiscordTwitterBlueskyThreadsMastodonYouTubeGitHub
© 2026 Obsidian

Fit

joshuaktojoshuakto51k downloads

Minimalist File gIT (FIT) to sync your files across mobile and desktop devices using GitHub.

Add to Obsidian
  • Overview
  • Scorecard
  • Updates21

Sync your files across mobile and desktop devices with one click.

Community project

This project is a community collaboration. If you'd like to contribute please check out the Discussions section on GitHub to suggest or discuss ideas.

Features

  • Universally supported: sync your vault across multiple devices, supports both mobile and desktop
  • Auto sync is now available 🎉
  • One-click to sync your vault
  • Conflict resolution: Stores conflicting changes from remote in the local _fit folder so you can resolve conflicts after sync
  • Guided setup: Intuitive settings, easy to configure even if you are new to GitHub
  • Works with existing vaults or repos

Note: This plugin is still in beta, please backup your vault before using this plugin.

Quick demo

Kapture 2024-03-15 at 17 37 07

Setup

  1. Create a personal access token with read/write access to the repo for your vault (refer to Github: creating a personal access token). For fine-grained tokens, the only required permission is Contents: Read and Write under Repository permissions. For classic tokens, the repo scope covers this (though it grants broader access than strictly needed).
  2. Once the personal access token is filled in, you can authenticate the user. The GitHub username, list of repositories, and branches will auto-populate.
  3. Select a repo and branch and you are ready to sync.Screenshot of FIT settings for tokens and repos

NOTE: For security, it's recommended to limit the token scope to only the necessary repository for your vault and avoid sharing your entire plugin settings file that contains this token.

How Sync Works

What gets synced

✅ Synced files:

  • Regular markdown files (.md)
  • Attachments (images, PDFs, etc.)
  • Any files in your vault root

❌ NOT synced (protected paths):

  • .obsidian/ folder (Obsidian settings and plugins)
  • _fit/ folder (conflict resolution area)
  • Hidden files like .gitignore, .env (not currently supported - see #92 for planned opt-in support)

Conflict handling

When the same file is modified both locally and remotely, FIT:

  • Keeps your local version in place
  • Saves the remote version to _fit/path/to/file.md
  • You can manually compare and merge the versions
  • If the same file clashes again before you resolve it, the _fit/ version is overwritten with the latest remote version (sync doesn't fail)

See Common Issues below for detailed conflict resolution steps.

First sync

  • It is advised to use a new repo for syncing an existing vault, to minimize the chance of file name conflict on the first sync
  • If your existing vault or repo is large, the initial sync would take longer and require a good internet connection

Manually trigger sync on Obsidian mobile

related issue: #190

On Obsidian mobile, linking sync to a hotkey which requires the presence of a keyboard is not an ideal approach to manually trigger sync. A more intuitive set of procedures are:

  • Open any repository with FIT configured
  • Swipe down from anywhere on the screen to open command menu
  • Search for "Fit: Fit Sync" and click to sync

Alternative: "Fit Sync" can be pinned to the ribbon menu from "Setting > Appearance > Interface > Ribbon menu configuration"

🔒 Security

The FIT maintainers make every effort to protect your security and protect against data loss. However, mistakes can happen. Users are highly recommended to do a security review of the code of this project before trusting it with their data. You could use an AI tool for that such as Claude Code.

You should also take care with security tokens you use to ensure they don't leak, because anyone with access to those can read and write your vault repository even if it's private (or worse if you configure broad unrestricted permissions on your token). In particular, avoid syncing your .obsidian/ files with other tools if you don't know what you're doing, and consider adding .gitignore rules to ignore .obsidian/ paths if you'll be syncing anything using git (FIT itself never syncs .obsidian/ - see How Sync Works).

Common Issues

📁 Empty directories not syncing

Why: Git (and GitHub) doesn't track empty directories. This is a fundamental limitation of Git, not a FIT bug.

Solution: Add a placeholder file like _gitkeep or README.md to keep the folder. Empty folders will only sync once they contain files.

📦 File size limits - "input too large" errors

Why: GitHub API has file size limits (~100MB hard limit, issues with files >10MB).

Symptoms: Error messages like "input too large to process" or "File 'X' is too large..."

Solutions:

  • Move large files (>20MB) outside your vault before syncing
  • Manually sync large files to GitHub using other tools (to create them and any time they're modified)
  • Add the files to .gitignore to exclude them from sync (once .gitignore is supported, #92)
⚠️ Sync conflicts - files in `_fit/` folder

What happens: When the same file is modified locally AND on GitHub, FIT saves both versions:

  • Your local version stays in place
  • The remote version is saved to _fit/path/to/file.md

How to resolve:

  1. Find conflict files in the _fit/ folder
  2. Compare both versions
  3. Manually merge the changes you want to keep
  4. Delete the _fit/ version when done
  5. Sync again

Prevention: Sync regularly (enable auto-sync) and avoid editing the same file on multiple devices simultaneously.

🖼️ Images/PDFs showing as corrupted text in GitHub

Symptoms: Binary files (JPG, PNG, PDF) appear as gibberish text in GitHub like ����JFIF��... instead of displaying properly

Cause: Bug in v1.4.0-beta.3 where binary files were incorrectly read as text on some platforms

Solution:

  1. Check file history in GitHub to find bad changes
  2. Use git to restore previous versions OR manually copy from history
  3. Update to v1.4 stable when available or a different beta version
  4. Re-sync - files will upload correctly

Note: This only affected beta versions. Images and PDFs sync correctly in v1.4+.

More info: See https://github.com/joshuakto/fit/issues/156 about the regression and older "correct format" error.

Roadmap

See CONTRIBUTING.md for current milestone and long-term priorities.

Relevant plugins

There are other community plugins with more advanced git features, if you need features such as branching of your repo, Git is a nice plugin to check out.

There are also other plugins for synchronizing changes such as Git integration, GitHub sync, and YAOS. However, they do not support mobile yet as of writing this plugin.

Developer Documentation

For developers interested in contributing to FIT or understanding its architecture, comprehensive documentation is available in the docs/ directory in GitHub.

Acknowledgements

  • This plugin used Obsidian Sample Plugin as a template.
  • This plugin uses Octokit to interface with GitHub rest api across devices.
80%
HealthExcellent
ReviewCaution
About
Sync your vault across mobile and desktop with one click or enable automatic syncing via GitHub. Save conflicting remote changes into a local _fit folder for manual comparison and merges without failing the sync. Include Markdown files and attachments while excluding .obsidian settings and hidden files.
Git
Details
Current version
1.4.0
Last updated
4 months ago
Created
2 years ago
Updates
21 releases
Downloads
51k
Compatible with
Obsidian 1.9.10+
License
MIT
Report bugRequest featureReport plugin
Sponsor
Buy Me a Coffee
Author
joshuaktojoshuakto
github.com/joshuakto
GitHubjoshuakto
  1. Community
  2. Plugins
  3. Git
  4. Fit

Related plugins

GitHub

GitHub Sync

Sync vault to personal GitHub.

Plugin Update Tracker

Know when installed plugins have updates and evaluate the risk of upgrading.

Git

Integrate Git version control with automatic backup and other advanced features.

Open in Terminal

Open your vault in a new terminal window or launch Claude Code, Codex CLI, or Gemini CLI directly from a terminal.

Better Plugins Manager

Make plugin management more intuitive and efficient.

GitHobs

Use Obsidian as Github issue editor with logic taken from Git

Notes Sync Share

Sync and share (publish) your notes in your own private service.

Version History Diff (Sync, File Recovery & Git)

Diff the version history of the core Sync and File Recovery plugins and Git for the active file.

Git File Explorer

Add relevant git information of detected git repositories to the file explorer.

Static Site MD Exporter

Export specific notes to general Markdown files for static page generator like Hugo, Hexo, Astro and more.