#sftp #fuse #cli-applications #cli-command #sshfs

bin+lib sftpman

A CLI application and library for managing and mounting sshfs (SFTP) filesystems

3 stable releases

new 2.0.2 Jan 7, 2025

#514 in Filesystem

Download history 255/week @ 2025-01-02

255 downloads per month
Used in sftpman-iced

AGPL-3.0-or-later

73KB
1.5K SLoC

sftpman

sftpman is a command line application for Linux systems that makes it easy to setup and mount sshfs/SFTP filesystems.

Configuration data is stored as JSON files in $XDG_CONFIG_HOME/sftpman (see the XDG Base Directory Specification) or $HOME/sftpman.

Under the hood, sshfs is used to do all the filesystem mounting work. Filesystems are mounted locally under the /mnt/sshfs/ directory by default (e.g. /mnt/sshfs/my-fs), but custom mount endpoints are also supported.

There's also a companion 🖥️ GUI application - sftpman-iced.

💡 Note: sftpman used to be written in Python (see sftpman-python) and had an sftman-gtk GUI frontend (also written in Python). Since this Rust rewrite appeared, the old Python-based applications are no longer maintained.

🚀 Installing

Dependencies

Installing on ArchLinux

For ArchLinux, there's an sftpman package in the AUR.

Installing on other distributions

For other Linux distributions you can install using cargo:

cargo install sftpman

You also need to:

  • install sshfs yourself

  • make sure the /mnt/sshfs directory exists and is writable (e.g. mkdir /mnt/sshfs && chown root:users /mnt/sshfs && chmod 0775 /mnt/sshfs)

⌨ CLI Application

Once you've 🚀 installed the CLI application, you can:

  • check if your system satisfies the prerequisites by running: sftpman preflight_check
  • manage filesystems via commands like: sftpman create, sftpman update and sftpman rm, etc.
  • mount filesystems via commands like: sftpman mount my-fs-1 my-fs-2 or sftpman mount_all
  • unmount filesystems via commands like: sftpman umount my-fs my-fs-2 or sftpman umount_all
  • list filesystems via commands like: sftpman ls available, sftman ls mounted or sftpman ls unmounted

See sftpman --help for more information.

🖥️ GUI Application

sftpman-iced is a frontend for sftpman built with the iced UI library.

💡 Note: Installing the GUI application will automatically pull the library provided here (libsftpman) as a dependency, but will not automatically install the sftpman CLI binary.

❓ FAQ

Why not just use sshfs directly?

You certainly can use sshfs directly or wrap it in your own scripts.

sftpman aims to be a higher-level wrapper around sshfs, so you don't have to do such manual work.

Having a 🖥️ GUI application also makes things easier.

Does sftpman support other protocols (FTP, etc)?

This has been discussed in this old issue.

As should be evident from the project name (sftpman), only SFTP is being targeted.

Other protocols are out of scope for this project.

Why was sftpman rewritten from Python to Rust?

The Python version of sftpman has worked well for more than a decade (2011-2025), but:

  • packaging Python application is somewhat annoying. Major Python version upgrades change the site-packages path and necessitate a rebuild.

  • Rust is very suitable for systems programs (like sftpman). The code is much cleaner and more reliable.

Is sftpman v2 compatible with sftpman v1?

sftpman v2 (and the 🖥️ GUI application - sftpman-iced) are still mostly-backward compatible with the old Python-based sftpman software (sftpman-python and the associated sftman-gtk):

  • ✅ The old configuration files can be read and used as-is

  • ✅ Most CLI commands are the same

  • ✨ You can now use custom local mount endpoints for filesystems, instead of just the default /mnt/sshfs/{id} directory

  • ❌ Some CLI commands for sftpman and their options have different names (sftpman setup being replaced by sftpman create and sftpman update; --auth_method being replaced by --auth_type)

Dependencies

~11–23MB
~342K SLoC