Skip to main content

Open-source Dropbox client for macOS and Linux.

Project description

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 version 0.3.0, Maestral does support the syncing of multiple Dropbox accounts.

The focus on "simple" file syncing does come with advantages: on macOS, the Maestral App bundle is 80% smaller than the official Dropbox app (50 MB vs 290 MB) and uses much less memory (100 MB vs 800 MB for a medium sized Dropbox on macOS). The memory usage will depend on the size of your synced Dropbox folder and can be further reduced when running Maestral without a GUI.

Installation

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

$ python3 -m pip install --upgrade maestral

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

For the Maestral daemon to integrate with systemd, please install the systemd extra:

$ python3 -m pip install --upgrade maestral[systemd]

Details on systemd integration are given in the Wiki.

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 the Maestral GUI. Creates a sync daemon if not already running.
  • maestral start|stop: Starts or stops the Maestral sync daemon.
  • maestral pause|resume: Pauses or resumes syncing.
  • maestral status: Gets the current status of Maestral.
  • maestral file-status LOCAL_PATH: Gets the sync status of an individual file or folder.
  • maestral set-dir LOCAL_PATH: Sets the location of your local Dropbox folder.
  • maestral excluded add|remove|list: Command group to manage excluded folders.
  • maestral ls DROPBOX_PATH: Lists the contents of a directory on Dropbox.
  • maestral log show|clear|level: Command group to manage logging.

Maestral currently supports the syncing of multiple Dropbox accounts by running multiple instances. This needs to be configured 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 add "personal"
$ maestral config add "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.

  • Error reporting is powered by bugsnag:

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

maestral-0.6.1.tar.gz (207.4 kB view details)

Uploaded Source

Built Distribution

maestral-0.6.1-py3-none-any.whl (343.2 kB view details)

Uploaded Python 3

File details

Details for the file maestral-0.6.1.tar.gz.

File metadata

  • Download URL: maestral-0.6.1.tar.gz
  • Upload date:
  • Size: 207.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.6

File hashes

Hashes for maestral-0.6.1.tar.gz
Algorithm Hash digest
SHA256 9140c1d35e0df1ef27955da29b20e2bd88f7f3a611e91a79de2c7d08377a60dc
MD5 86e374cc797d0e6b9baf6c339df470c0
BLAKE2b-256 121219db97998578c142dc34af52087e0a7b2819c5f7c1373138ae62fb5d1ca8

See more details on using hashes here.

File details

Details for the file maestral-0.6.1-py3-none-any.whl.

File metadata

  • Download URL: maestral-0.6.1-py3-none-any.whl
  • Upload date:
  • Size: 343.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.6

File hashes

Hashes for maestral-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 dc3e322c5a478ae19a606b70c978242d52118810d9267d0f5b144b8ed54626ed
MD5 c80e0ec40187085d3ed337478f6ee71b
BLAKE2b-256 4f7f95a185c7bfa56817296492f1ff6690405f8d3305beb7a9fa525de75cd63c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page