npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@jrussellsmyth/fit-cli

v1.4.7-cli.0

Published

A CLI tool for autonomous agent and CI pipeline management of an Obsidian (https://obsidian.md) vault, built on top of FIT (https://github.com/joshuakto/fit).

Readme

FIT

Obsidian Downloads

⚠️ This is a fork of joshuakto/fit. It adds a CLI interface (fit-cli) for automation and autonomous agent workflows. A pull request has been submitted to the upstream project. For the original Obsidian plugin, see joshuakto/fit. For the CLI tool, see @jrussellsmyth/fit-cli on npm or README.cli.md.

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)
  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.

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

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.

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)

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.

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.

"Buy Me A Coffee"

Developer Documentation

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

fit-cli: Automation & CI

FIT ships a companion command-line tool, fit-cli, that exposes the same sync engine as the Obsidian plugin. It is intended for use in automation workflows and CI/CD pipelines where Obsidian is not running, such as scripting note organization or task management with an autonomous agent.

Build

npm run cli:build   # produces fit-cli.cjs

Usage

# Show help
node fit-cli.cjs help

# Check pending changes (dry-run, machine-readable)
node fit-cli.cjs status --vault /path/to/vault --json

# Sync vault with remote
node fit-cli.cjs sync --vault /path/to/vault

When installed globally (npm install -g .), the binary is available as fit-cli:

fit-cli sync
fit-cli status --json

Configuration

Options can be supplied as flags, environment variables, or a JSON config file (all three can be combined; flags take highest priority).

| Flag | Environment variable | Description | |---|---|---| | --vault <path> | FIT_VAULT | Path to the Obsidian vault directory | | --pat <token> | FIT_PAT | GitHub personal access token | | --owner <owner> | FIT_OWNER | GitHub repository owner | | --repo <repo> | FIT_REPO | GitHub repository name | | --branch <branch> | FIT_BRANCH | Branch to sync (default: main) | | --device <name> | FIT_DEVICE | Device name used in commit messages | | --config <path> | FIT_CONFIG | Path to a JSON config file | | --state <path> | (none) | Path to state file (default: <vault>/.fit-state.json) | | --json | (none) | Output results as JSON | | --verbose | (none) | Enable verbose logging to stderr |

Config file (~/.fit-cli.json by default):

{
  "vaultPath": "/path/to/vault",
  "pat": "ghp_...",
  "owner": "username",
  "repo": "vault-repo",
  "branch": "main",
  "deviceName": "my-agent"
}

Sync behaviour

fit-cli uses the same sync engine as the Obsidian plugin — conflict detection, _fit/ staging, and protected path rules all behave identically. State (SHA caches) is persisted to <vault>/.fit-state.json by default so that incremental syncs are efficient.

Acknowledgements