Skip to content
Open-source Dropbox client for macOS and Linux
Python Shell
Branch: master
Clone or download
Latest commit b44f337 Aug 15, 2019
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.github/ISSUE_TEMPLATE Update bug_report.md Aug 14, 2019
bin tweaks and version bump to v.0.1.2-dev0 Jun 24, 2019
maestral released bug fix version v0.3.1 Aug 14, 2019
screenshots cropped macOS screenshot Aug 14, 2019
.gitattributes Initial commit Nov 26, 2018
.gitignore updated gitignore Jul 24, 2019
.travis.yml added travis.yml Aug 10, 2019
CHANGELOG.md released bug fix version v0.3.1 Aug 14, 2019
LICENSE.txt Initial commit Nov 26, 2018
README.md Update README.md Aug 15, 2019
requirements.txt
setup.py added maestral daemon Aug 14, 2019

README.md

PyPi Release Pyversions

Maestral

A light-weight and open-source Dropbox client for macOS and Linux.

About

Maestral is an open-source Dropbox client written in Python. The project's main goal is to provide a client for platforms and file systems that are no longer directly supported by Dropbox.

Currently, Maestral does not support Dropbox Paper, the management of Dropbox teams and the management of shared folder settings. If you need any of this functionality, please use the Dropbox website or the official client. As of v0.3, Maestral does however support the syncing of multiple Dropbox accounts.

The focus on "simple" file syncing does come with advantages: the Maestral App on macOS is 80% smaller than the official Dropbox app (50 MB vs 290 MB) and uses 70% less memory. The app size and memory footprint can be further reduced when installing and running Maestral without a GUI and using the Python installation provided by your OS. The Maestral code itself and its Python dependencies take up less than 3 MB, making an install without GUI ideal for systems with little resources.

Installation

A binary is provided for macOS High Sierra and higher and can be downloaded from the Releases tab. On other platforms, download and install the Python package from PyPI:

$ python3 -m pip install --upgrade maestral

You can also install the latest beta:

$ python3 -m pip install --upgrade --pre maestral

If you intend to use the graphical user interface, you also need to install PyQt5, either from PyPI or form your platforms package manager.

Usage

Run maestral gui in the command line (or open the Maestral app on macOS) to start Maestral with a graphical user interface. On its first run, Maestral will guide you through linking and configuring your Dropbox and will then start syncing.

screenshot macOS screenshot Fedora

Command line usage

After installation, Maestral will be available as a command line script by typing maestral in the command prompt. Type maestral --help to get a full list of available commands. The most important are:

  • maestral gui: Starts Maestral with a GUI.
  • maestral daemon {start/stop}: Starts or stops Maestral as a daemon.
  • maestral daemon {pause/resume}: Pauses or resumes syncing.
  • maestral daemon status: Gets the current sync status.
  • maestral daemon errors: Lists all sync errors.
  • maestral set-dir: Sets the location of your local Dropbox folder.
  • maestral dir-exclude: Excludes a Dropbox folder from syncing.
  • maestral dir-inlcude: Includes a Dropbox folder in syncing.
  • maestral list: Lists the contents of a directory on Dropbox.

Maestral currently supports the syncing of multiple Dropbox accounts by running multiple instances. This needs to be done from the command line. For example, before running maestral gui, one can set up a new configuration with maestral config new. The configuration name should then be given as command line option --config-name before running maestral. For example:

$ maestral config new "personal"
$ maestral config new "work"
$ maestral gui --config-name="personal"
$ maestral gui --config-name="work"

This will start two instances of Maestral, syncing a private and a work account, respectively. Multiple Maestral daemons are supported as well.

By default, the Dropbox folder names will contain the capitalised config-name in braces. In the above case, this will be "Dropbox (Personal)" and "Dropbox (Work)".

Contribute

The following tasks could need your help:

  • Write tests for Maestral.
  • Detect and warn in case of unsupported Dropbox folder locations (network drives, external hard drives, etc).
  • Native Cocoa and GTK interfaces. Maestral currently uses PyQt5.
  • Packaging: improve packing for macOS (reduce app size) and package for other platforms.

Warning:

  • Maestral is still in beta status. Even though highly unlikely, using it may potentially result in loss of data.
  • Network drives and some external hard drives are not supported as locations for the Dropbox folder.

Dependencies

Acknowledgements

  • The config module uses code from the Spyder IDE.
  • The MaestralApiClient is based on the work from Orphilia.
You can’t perform that action at this time.